JSON

c#常用的Datable转换为json,以及json转换为DataTable操作方法

字号+ 作者:H5之家 来源:H5之家 2017-04-11 16:03 我要评论( )

1.[代码][C#]Datatable和json互相转换操作 跳至 #region DataTable 转换为Json字符串实例方法/// summary/// GetClassTypeJosn 的摘要说明/// /summarypublic class GetClassTypeJosn : IHttpHandler{/// summary/// 文件名:DataTable 和Json 字符串互转///

1. [代码][C#]Datatable和json互相转换操作     跳至 #region DataTable 转换为Json字符串实例方法 /// <summary> /// GetClassTypeJosn 的摘要说明 /// </summary> public class GetClassTypeJosn : IHttpHandler { /// <summary> /// 文件名:DataTable 和Json 字符串互转 /// 版权所有:Copyright (C) Create Family Wealth liangjw /// 创建标示:2013-08-03 /// </summary> //用法说明实例 public void ProcessRequest(HttpContext context) { context.Response.ContentType = "application/json"; context.Response.Charset = "utf-8"; HttpRequest req = context.Request; string method = req["method"].ToStr().ToLower(); //获取合同明细列表 DataTable 转换为Json字符串 if (method == "txtdate") { string json = ""; BO.MakeContractMx bll = new MakeContractMx(); DataSet ds = bll.GetDataTable(); if (ds.Tables.Count > 0) { json =ToJson(ds.Tables[0]); } context.Response.Write(json); return; } } public bool IsReusable { get { return false; } } } #endregion #region Json字符串转换为DataTable 实例方法 public DataTable JsonToDataTable(json) { DataTable dt= ToDataTable(json); return dt; } #endregion #region DataTable 转换为Json 字符串 /// <summary> /// DataTable 对象 转换为Json 字符串 /// </summary> /// <param></param> /// <returns></returns> public static string ToJson(this DataTable dt) { JavaScriptSerializer javaScriptSerializer = new JavaScriptSerializer(); javaScriptSerializer.MaxJsonLength = Int32.MaxValue; //取得最大数值 ArrayList arrayList = new ArrayList(); foreach (DataRow dataRow in dt.Rows) { Dictionary<string, object> dictionary = new Dictionary<string, object>(); //实例化一个参数集合 foreach (DataColumn dataColumn in dt.Columns) { dictionary.Add(dataColumn.ColumnName, dataRow[dataColumn.ColumnName].ToStr()); } arrayList.Add(dictionary); //ArrayList集合中添加键值 } return javaScriptSerializer.Serialize(arrayList); //返回一个json字符串 } #endregion #region Json 字符串 转换为 DataTable数据集合 /// <summary> /// Json 字符串 转换为 DataTable数据集合 /// </summary> /// <param></param> /// <returns></returns> public static DataTable ToDataTable(this string json) { DataTable dataTable = new DataTable(); //实例化 DataTable result; try { JavaScriptSerializer javaScriptSerializer = new JavaScriptSerializer(); javaScriptSerializer.MaxJsonLength = Int32.MaxValue; //取得最大数值 ArrayList arrayList = javaScriptSerializer.Deserialize<ArrayList>(json); if (arrayList.Count > 0) { foreach (Dictionary<string, object> dictionary in arrayList) { if (dictionary.Keys.Count<string>() == 0) { result = dataTable; return result; } if (dataTable.Columns.Count == 0) { foreach (string current in dictionary.Keys) { dataTable.Columns.Add(current, dictionary[current].GetType()); } } DataRow dataRow = dataTable.NewRow(); foreach (string current in dictionary.Keys) { dataRow[current] = dictionary[current]; } dataTable.Rows.Add(dataRow); //循环添加行到DataTable中 } } } catch { } result = dataTable; return result; } #endregion #region 转换为string字符串类型 /// <summary> /// 转换为string字符串类型 /// </summary> /// <param>获取需要转换的值</param> /// <param>需要格式化的位数</param> /// <returns>返回一个新的字符串</returns> public static string ToStr(this object s, string format = "") { string result = ""; try { if (format == "") { result = s.ToString(); } else { result = string.Format("{0:" + format + "}", s); } } catch { } return result; } #endregion

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • 学习完毕常用的TCP/IP功能后,有两个很有必要学习的,一个JSON,还有个MQTT

    学习完毕常用的TCP/IP功能后,有两个很有必要学习的,一个JSON,还有

    2017-01-27 10:01

  • 一些非常实用的JSON 教程

    一些非常实用的JSON 教程

    2016-11-18 16:00

  • 实用的javascript小技巧

    实用的javascript小技巧

    2016-01-25 19:05

  • 从XML生成可和Ajax共同使用的JSON.doc

    从XML生成可和Ajax共同使用的JSON.doc

    2016-01-15 18:21

网友点评