代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
CSharp
】
两个DataTable的加减乘除
作者:
kunkun0921
/ 发布于
2015/1/26
/
1135
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data; namespace ConsoleApp { /// <summary> /// 重写DataTable,重载操作符 /// </summary> class MyDataTable : DataTable { public static MyDataTable operator -(MyDataTable first, MyDataTable second) { MyDataTable temp = first; for (int i = 0; i < first.Rows.Count; i++) { temp.Rows[i][1] = Convert.ToInt32(first.Rows[i][1]) + Convert.ToInt32(second.Rows[i][1]); temp.Rows[i][2] = first.Rows[i][2].ToString() + "+" + second.Rows[i][2].ToString(); temp.Rows[i][3] = Convert.ToInt32(first.Rows[i][3]) - Convert.ToInt32(second.Rows[i][3]); } return temp; } public static MyDataTable operator &(MyDataTable first, MyDataTable second) { MyDataTable temp = first; for (int i = 0; i < first.Rows.Count; i++) { temp.Rows[i][1] = Convert.ToInt32(first.Rows[i][1]) * Convert.ToInt32(second.Rows[i][1]); temp.Rows[i][2] = first.Rows[i][2].ToString() + "/" + second.Rows[i][2].ToString(); temp.Rows[i][3] = Convert.ToInt32(first.Rows[i][3]) / Convert.ToInt32(second.Rows[i][3]); } return temp; } } /// <summary> /// 对datatable进行操作符重载 /// </summary> class PackDataTableOperator { public static void Run() { MyDataTable dt1 = new MyDataTable(); dt1.Columns.AddRange(new DataColumn[] { new DataColumn("itemname", typeof(System.String)), new DataColumn("col1", typeof(System.Int32)), new DataColumn("col2", typeof(System.String)), new DataColumn("col3", typeof(System.Int32)) }); DataRow newRow; for (int i = 0; i < 5; i++) { newRow = dt1.NewRow(); newRow["itemname"] = "item_" + i.ToString() + ":"; newRow["col1"] = ((i + 1) * 2).ToString(); newRow["col2"] = ((i + 2) * 2).ToString(); newRow["col3"] = ((i + 3) * 2).ToString(); dt1.Rows.Add(newRow); } MyDataTable dt2 = new MyDataTable(); dt2.Columns.AddRange(new DataColumn[] { new DataColumn("itemname", typeof(System.String)), new DataColumn("col1", typeof(System.Int32)), new DataColumn("col2", typeof(System.Int32)), new DataColumn("col3", typeof(System.Int32)) }); for (int i = 0; i < 5; i++) { newRow = dt2.NewRow(); newRow["itemname"] = "item_" + i.ToString() + ":"; newRow["col1"] = ((i + 2) * 3).ToString(); newRow["col2"] = ((i + 3) * 3).ToString(); newRow["col3"] = ((i + 4) * 4).ToString(); dt2.Rows.Add(newRow); } int length = dt1.Rows.Count; Console.WriteLine("dt1操作前的数据:"); for (int i = 0; i < length; i++) { Console.WriteLine(dt1.Rows[i]["itemname"].ToString() + "_" + dt1.Rows[i]["col1"].ToString() + "_" + dt1.Rows[i]["col2"].ToString() + "_" + dt1.Rows[i]["col3"].ToString()); } Console.WriteLine("dt2操作前的数据:"); for (int i = 0; i < length; i++) { Console.WriteLine(dt2.Rows[i]["itemname"].ToString() + "_" + dt2.Rows[i]["col1"].ToString() + "_" + dt2.Rows[i]["col2"].ToString() + "_" + dt2.Rows[i]["col3"].ToString()); } Console.WriteLine("temp操作(-)后的数据:"); MyDataTable temp = dt1 - dt2; for (int i = 0; i < length; i++) { Console.WriteLine(temp.Rows[i]["itemname"].ToString() + "_" + temp.Rows[i]["col1"].ToString() + "_" + temp.Rows[i]["col2"].ToString() + "_" + temp.Rows[i]["col3"].ToString()); } Console.WriteLine("temp操作(&)后的数据:"); temp = dt1 & dt2; for (int i = 0; i < length; i++) { Console.WriteLine(temp.Rows[i]["itemname"].ToString() + "_" + temp.Rows[i]["col1"].ToString() + "_" + temp.Rows[i]["col2"].ToString() + "_" + temp.Rows[i]["col3"].ToString()); } } } }
试试其它关键字
DataTable
同语言下
.
文件IO 操作类库
.
Check图片类型[JPEG(.jpg 、.jpeg),TIF,GIF,BMP,PNG,P
.
机器名和IP取得(IPV4 IPV6)
.
Tiff转换Bitmap
.
linqHelper
.
MadieHelper.cs
.
RegHelper.cs
.
如果关闭一个窗体后激活另一个窗体的事件或方法
.
创建日志通用类
.
串口辅助开发类
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
kunkun0921
贡献的其它代码
(
40
)
.
linq 基本方法
.
Form窗体关闭原因
.
消除button按下出现的虚线
.
GUID转换为Int64
.
将窗体固定在显示器的左上角
.
获取进程或线程的相关信息
.
判断当前操作用户的管理角色
.
两个DataTable的加减乘除
.
视频API类 摄像头
.
集合、DataTable互转
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3