DataTable一些操作
DataTable ReturnDt = new DataTable("Tab_Result");
ReturnDt.Columns.AddRange(new DataColumn[]
{
new DataColumn("序号", typeof(int)),
new DataColumn("分公司名称", typeof(string)),
new DataColumn("销售件数", typeof(int)),
new DataColumn("销售均价", typeof(decimal)),
new DataColumn("销售总额", typeof(decimal)),
new DataColumn("售前件数", typeof(int)),
new DataColumn("售后件数", typeof(int)),
new DataColumn("签约店数", typeof(int)),
new DataColumn("有效店数", typeof(int)),
new DataColumn("销售总件数", typeof(int)),
new DataColumn("总店数", typeof(int)),
});
int Count = ;
for (int i = ; i <= Count; i++)
{
System.Data.DataRow myRow = ReturnDt.NewRow();
myRow["序号"] = i;
myRow["分公司名称"] = "北京" + i;
myRow["销售件数"] = + i;
myRow["销售均价"] = Convert.ToDecimal(i.ToString()).ToString("0.00");
myRow["销售总额"] = Convert.ToDecimal(i.ToString()).ToString("0.00");
myRow["售前件数"] = i + ;
myRow["售后件数"] = i + ;
myRow["签约店数"] = i + ;
myRow["有效店数"] = i + ;
myRow["销售总件数"] = int.Parse(myRow["售前件数"].ToString()) + int.Parse(myRow["售后件数"].ToString());
ReturnDt.Rows.Add(myRow);
//需放在后面,不然赋值错误,可做为汇总列,没初始值
myRow["总店数"] = ReturnDt.Compute("Sum(签约店数)+Sum(有效店数)", "序号=" + i.ToString());
if (i == Count)
{
//添加汇总行
System.Data.DataRow myRow1 = ReturnDt.NewRow();
myRow1["序号"] = ;
myRow1["分公司名称"] = "汇总行";
myRow1["销售件数"] = ReturnDt.Compute("SUM(销售件数)", "");
myRow1["销售均价"] = ReturnDt.Compute("SUM(销售均价)", "");
myRow1["销售总额"] = ReturnDt.Compute("SUM(销售总额)", "");
myRow1["售前件数"] = ReturnDt.Compute("SUM(售前件数)", "");
myRow1["售后件数"] = ReturnDt.Compute("SUM(售后件数)", "");
myRow1["签约店数"] = ReturnDt.Compute("SUM(签约店数)", "");
myRow1["有效店数"] = ReturnDt.Compute("SUM(有效店数)", "");
myRow1["销售总件数"] = ReturnDt.Compute("SUM(销售总件数)", "");
myRow1["总店数"] = ReturnDt.Compute("SUM(总店数)", "");
//ReturnDt.Rows.Add(myRow1);//插入到最后一行
ReturnDt.Rows.InsertAt(myRow1, );//插入到第一行
}
}
//删除列
// ReturnDt.Columns.Remove("销售总件数");
//调整列顺序 ,列排序从0开始
ReturnDt.Columns["分公司名称"].SetOrdinal();
//修改列标题名称
ReturnDt.Columns["分公司名称"].ColumnName = "名称";
// ReturnDt.Rows.Remove(row);//根据row行信息删除
//ReturnDt.Rows.RemoveAt(1);//根据index索引删除
//查询序号大于等于5,并且按销售件数排序
EnumerableRowCollection<DataRow> query =
from order in ReturnDt.AsEnumerable()
where order.Field<int>("序号") <=
orderby order.Field<int>("销售总件数")
select order;
//复制表
DataTable boundTable = query.CopyToDataTable<DataRow>();
DataView view1 = query.AsDataView();
//view1.Sort = "序号 DESC";//降序
view1.Sort = "序号 ASC";//升序
view1.RowFilter = "序号 < 15";//筛选
//泛型转DataTable
List<People> list = new List<People>()
{
new People{ID=,Name="A",Sex="男",Age=,Tel="0871-8989898",Addres="四川南通市区1",Work="工程师",Income=8000.09,Birthday=System.DateTime.Now},
new People{ID=,Name="B",Sex="男",Age=,Tel="0871-8989898",Addres="四川南通市区2",Work="教师",Income=8010.09,Birthday=System.DateTime.Now},
new People{ID=,Name="S",Sex="男",Age=,Tel="0871-8989898",Addres="四川南通市区3",Work="博士",Income=8200.09,Birthday=System.DateTime.Now},
new People{ID=,Name="AD",Sex="男",Age=,Tel="0871-8989898",Addres="四川南通市区4",Work="工程师",Income=840.09,Birthday=System.DateTime.Now},
new People{ID=,Name="AA",Sex="男",Age=,Tel="0871-8989898",Addres="四川南通市区5",Work="工程师",Income=8500.09,Birthday=System.DateTime.Now},
new People{ID=,Name="AR",Sex="男",Age=,Tel="0871-8989898",Addres="四川南通市区6",Work="建筑师",Income=850.09,Birthday=System.DateTime.Now},
new People{ID=,Name="AW",Sex="男",Age=,Tel="0871-8989898",Addres="四川南通市区7",Work="工程师",Income=8000.09,Birthday=System.DateTime.Now},
new People{ID=,Name="AR",Sex="男",Age=,Tel="0871-8989898",Addres="四川南通市区8",Work="培训师",Income=860.069,Birthday=System.DateTime.Now},
new People{ID=,Name="AQ",Sex="男",Age=,Tel="0871-8989898",Addres="四川南通市区9",Work="工程师",Income=8900.09,Birthday=System.DateTime.Now},
};
System.Data.DataTable dt = ConvertToDataTable(list);
System.String str = ConvertToJson(dt);
System.Data.DataTable dt1 = JsonToDataTable(str);
}
public static DataTable JsonToDataTable(string strJson)
{
//取出表名
//var rg = new Regex(@"(?<={)[^:]+(?=:\[)", RegexOptions.IgnoreCase);
var rg = new Regex(@"([^:])+(?=:\{)", RegexOptions.IgnoreCase);
string strName = rg.Match(strJson).Value;
DataTable tb = null;
//去除表名
//strJson = strJson.Substring(strJson.IndexOf("{") + 1);
//strJson = strJson.Substring(0, strJson.IndexOf("}"));
//获取数据
//rg = new Regex(@"(?<={)[^}]+(?=})");
rg = new Regex(@"(?<={)[^}]+(?=})");
System.Text.RegularExpressions.MatchCollection mc = rg.Matches(strJson);
for (int i = ; i < mc.Count; i++)
{
string strRow = mc[i].Value;
string[] strRows = strRow.Split(',');
//创建表
if (tb == null)
{
tb = new DataTable();
tb.TableName = strName;
foreach (string str in strRows)
{
var dc = new DataColumn();
string[] strCell = str.Split(':');
dc.ColumnName = strCell[];
tb.Columns.Add(dc);
}
tb.AcceptChanges();
}
//增加内容
DataRow dr = tb.NewRow();
for (int r = ; r < strRows.Length; r++)
{
//dr[r] = strRows[r].Split(':')[1].Trim().Replace(",", ",").Replace(":", ":").Replace("\"", "");
dr[r] = strRows[r];
}
tb.Rows.Add(dr);
tb.AcceptChanges();
}
return tb;
}
//datatable转json
public static string ConvertToJson(DataTable dt)
{
StringBuilder jsonBuilder = new StringBuilder();
int count = dt.Rows.Count;
if (count != )
{
jsonBuilder.Append("[");
for (int i = ; i < dt.Rows.Count; i++)
{
jsonBuilder.Append("{");
for (int j = ; j < dt.Columns.Count; j++)
{
jsonBuilder.Append("");
jsonBuilder.Append(dt.Columns[j].ColumnName);
jsonBuilder.Append(":\'");
jsonBuilder.Append(dt.Rows[i][j].ToString());
jsonBuilder.Append("\',");
}
jsonBuilder.Remove(jsonBuilder.Length - , );
jsonBuilder.Append("},");
}
jsonBuilder.Remove(jsonBuilder.Length - , );
jsonBuilder.Append("]");
return jsonBuilder.ToString();
}
else
{
return null;
}
}
//泛型转Datatble
public static DataTable ConvertToDataTable<T>(IList<T> list)
{
if (list == null || list.Count <= )
{
return null;
}
DataTable dataTable = new DataTable(typeof(T).Name);
DataColumn column;
DataRow row;
System.Reflection.PropertyInfo[] PropertyInfo = typeof(T).GetProperties(System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Instance);
foreach (T t in list)
{
if (t == null)
{
continue;
}
row = dataTable.NewRow();
for (int i = , j = PropertyInfo.Length; i < j; i++)
{
System.Reflection.PropertyInfo pi = PropertyInfo[i];
string name = pi.Name;
if (dataTable.Columns[name] == null)
{
column = new DataColumn(name, pi.PropertyType);
dataTable.Columns.Add(column);
}
row[name] = pi.GetValue(t, null);
}
dataTable.Rows.Add(row);
}
return dataTable;
}
public class People
{
public string Name { get; set; }
public int Age { get; set; }
public string Tel { get; set; }
public string Addres { get; set; }
public int ID { get; set; }
public string Sex { get; set; }
public double Income { get; set; }
public string Work { get; set; }
public System.DateTime Birthday { get; set; }
}
DataTable一些操作的更多相关文章
- DataTable相关操作,筛选,取前N条数据,获取指定列数据
DataTable相关操作,筛选,取前N条数据,获取指定列数据2013-03-12 14:50 by Miracle520, 2667 阅读, 0 评论, 收藏, 编辑 1 #region DataT ...
- ASP.NET DataTable的操作大全
DataTable表示一个与内存有关的数据表,可以使用工具栏里面的控件拖放来创建和使用,也可以在编写程序过程中根据需要独立创建和使用,最常见的情况是作为DataSet的成员使用,在这种情况下就需要用在 ...
- DataTable多线程操作报错情况
最近在写一个http接口时用了DataTable这个强大的利器,接口用浏览器跑起来没任何问题.当时也没考虑并发问题,后来用一个压力测试工具做大并发测试,1000+/s次速度测试.发现程序报错了.程序报 ...
- Excel和datatable相互操作
/// <summary> /// Excel文档 /// </summary> /// <param name="table"></pa ...
- DataTable常用操作
添加列和行的三种方法(转载) 原文地址:http://www.cnblogs.com/jRoger/articles/1887581.html DataTable tblDatas =new Data ...
- datatable列操作
DataTable myDt =dt; //删除列 myDt.Columns.Remove("minArea"); myDt.Columns.Remove("max ...
- [C#]DataTable常用操作总结
].RowState == DataRowState.Unchanged) { //Your logic } //⑩Convert to ...
- jquery datatable 实例操作
var dataTables = $(".table").dataTable({ data: d,//为ajax的值,没有直接用插件自带的请求数据方式,个人觉得data的方式好控制 ...
- DataTable 常用操作
//定义表结构 DataTable dt = new DataTable(); dt.Columns.Add("FactoryId"); 或dt.Columns.Add(new D ...
随机推荐
- C#中A a=new B()的意义
A a=new B()的意义 前提:A是B的父类. A a = new B(); 或 A a; B b=new B(); a=b; 这一句的过程是这样的, 1)创建一个类A的引用a 2)创建一个类B的 ...
- java-常用快捷键
alt+/:代码提示 ctrl+/:代码提示 ctrl+1:快速生成impl代码
- 关于Parse库的配置问题
在使用Parse的一些相关服务时候,需要下载Parse的SDK,除了需要添加相应的系统框架和库的支持 AudioToolbox.framework CFNetwork.framework CoreGr ...
- Android 中 更新视图的函数ondraw() 和dispatchdraw()的区别
绘制VIew本身的内容,通过调用View.onDraw(canvas)函数实现 绘制自己的孩子通过dispatchDraw(canvas)实现 View组件的绘制会调用draw(Canvas canv ...
- Ebean Demo
ebean orm框架,其作者觉得hibernate的bean管理会话管理.难以在短时间明确,就自己搞了一套,就成了如今的ebean. ebean被一些开发人员这觉得是一把瑞士军刀.能够看出一些程序 ...
- Java基础知识强化之网络编程笔记02:Socket通信原理图解
1. Socket (1)Socket套接字 网络上具有唯一标识的IP地址和端口号组合在一起才能构成唯一能识别的标识符套接字 (2)Socket原理机制: • 通信两端都有Socket. • 网 ...
- Android(java)学习笔记189:eclipse 导入项目是提示:某些项目因位于工作空间目录中而被隐藏。
导致这个错误的原因是工程重名了: 并不是仅仅指文件夹重名,相信很多人也曾经修改过文件夹的名称,可惜没什么用处,关键是修改工程里面的一个文件!也就是.project这个文件! 用记事本打开,修改一下&l ...
- git操作github
转自http://www.cnblogs.com/fnng/archive/2012/01/07/2315685.html 怕找不到~ 本文在我之前的那篇<git/github学习笔记>的 ...
- 让IE支持Css3属性(圆角、阴影、渐变)
>>>>>>>>>>>>>>>>>>>>>>>>> ...
- ueditor 添加微软雅黑字体 异常“从客户端中检测到有潜在危险的 request.form值”,解决
使用ueditor往数据库添加文本内容时,如果字体有css样式, <,>," 这些字符会导致报出异常信息:从客户端中检测到有潜在危险的 request.form值 因为这些字符有 ...