DataTable 转换成 Json的3种方法
在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:List<T>、DataTable转换为Json格式。特别在使用Extjs框架的时候,Ajax异步请求的数据格式就是Json。鉴于此,我今天来分享将DataTable 转换成 Json的3种方法。换句话说如何在ASP.NET将一个DataTable序列化为 Json数组。或者如何从一个DataTable返回一个Json字符串。这篇文章将采用StringBuilder,JavaScriptSerializer和 Json.Net DLL (Newtonsoft) 这3种方法实现这一目标。
Json概述
JavaScript Object Notation (Json)是一种轻量级的数据交换格式。它基于ECMAScript的一个子集。这些特性使Json成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成(一般用于提升网络传输速率)。Json采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯,包括C、C++、C#、Java、JavaScript、Perl、Python等等。
这些特性使Json成为一种理想的数据交换语言。因此 基于AJAX应用程序,Json已经成为一种用于数据交换的流行格式。总之,Json是一种存储和交换数据的语法,易于操作,也是除XML之外的不二之选。
步骤:
首先我们从Microsoft SQL Server 获取数据到DataTable,也可以给DataTable动态添加行。代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | private DataTable getData() { DataTable dt = new DataTable(); dt.Columns.Add( "编号" , typeof (Int32)); dt.Columns.Add( "姓名" , typeof ( string )); dt.Columns.Add( "性别" , typeof ( string )); dt.Columns.Add( "学历" , typeof ( string )); dt.Rows.Add(1, "王超" , "男" , "本科" ); dt.Rows.Add(2, "周丽" , "女" , "专科" ); dt.Rows.Add(3, "李娟" , "女" , "专科" ); dt.Rows.Add(4, "杨明" , "男" , "硕士" ); dt.Rows.Add(5, "张德" , "男" , "本科" ); return dt; } |
下面开始通过每一种方法实现DataTable转换成 Json 对象。
方法1:使用StringBuilder
这是Json样本数据的样子: {"姓名 ":"张三", "年龄":"30"}。Json里用花括号保存对象,它可以包含多个名称/值对。所以使用StringBuilder我们可以创建一个类似的Json字符串。
由于要使用StringBuilder类,我们首先需要导入System.Text命名空间,如下:
1 | using System.Text; |
下面的代码将生成一个Json字符串,遍历DataTable的行和列,获取数据,添加到一个StringBuilder对象 JsonString,然后返回这个对象。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 | public string DataTableToJson(DataTable table) { var JsonString = new StringBuilder(); if (table.Rows.Count > 0) { JsonString.Append( "[" ); for ( int i = 0; i < table.Rows.Count; i++) { JsonString.Append( "{" ); for ( int j = 0; j < table.Columns.Count; j++) { if (j < table.Columns.Count - 1) { JsonString.Append( "\"" + table.Columns[j].ColumnName.ToString() + "\":" + "\"" + table.Rows[i][j].ToString() + "\"," ); } else if (j == table.Columns.Count - 1) { JsonString.Append( "\"" + table.Columns[j].ColumnName.ToString() + "\":" + "\"" + table.Rows[i][j].ToString() + "\"" ); } } if (i == table.Rows.Count - 1) { JsonString.Append( "}" ); } else { JsonString.Append( "}," ); } } JsonString.Append( "]" ); } return JsonString.ToString(); } |
方法2:使用 JavaScriptSerializer.
首先我们添加System.Web.Script.Serialization命名空间,如下:
1 | using System.Web.Script.Serialization; |
JavaScriptSerializer这个类是由异步通信层内部使用来序列化和反序列化数据。如果序列化一个对象,就使用序列化方法。反序列化Json字符串,使用Deserialize或DeserializeObject方法。在这里,我们使用序列化方法得到Json格式的数据。代码以下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | public string DataTableToJsonWithJavaScriptSerializer(DataTable table) { JavaScriptSerializer jsSerializer = new JavaScriptSerializer(); List < Dictionary < string , object >> parentRow = new List < Dictionary < string , object >> (); Dictionary < string , object > childRow; foreach (DataRow row in table.Rows) { childRow = new Dictionary < string , object > (); foreach (DataColumn col in table.Columns) { childRow.Add(col.ColumnName, row[col]); } parentRow.Add(childRow); } return jsSerializer.Serialize(parentRow); } |
方法3:使用Json.Net DLL (Newtonsoft)。
这个方法中要添加Json.Net DLL引用,我们可以从Newtonsoft下载Json.Net DLL,再导入命名空间,代码如下:
1 2 3 4 5 6 7 8 | using Newtonsoft.Json; public string DataTableToJsonWithJsonNet(DataTable table) { string JsonString= string .Empty; JsonString = JsonConvert.SerializeObject(table); return JsonString; } |
效果图:
StringBuilder方法的全部代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 | using System; using System.Text; using System.Data; public partial class Default2 : System.Web.UI.Page { private string sasss; protected void Page_Load( object sender, EventArgs e) { DataTable table = getData(); sasss = DataTableToJson(table); Response.Write(sasss + "<br/>" ); } public string DataTableToJson(DataTable table) { var JsonString = new StringBuilder(); if (table.Rows.Count > 0) { JsonString.Append( "[" ); for ( int i = 0; i < table.Rows.Count; i++) { JsonString.Append( "{" ); for ( int j = 0; j < table.Columns.Count; j++) { if (j < table.Columns.Count - 1) { JsonString.Append( "\"" + table.Columns[j].ColumnName.ToString() + "\":" + "\"" + table.Rows[i][j].ToString() + "\"," ); } else if (j == table.Columns.Count - 1) { JsonString.Append( "\"" + table.Columns[j].ColumnName.ToString() + "\":" + "\"" + table.Rows[i][j].ToString() + "\"" ); } } if (i == table.Rows.Count - 1) { JsonString.Append( "}" ); } else { JsonString.Append( "}," ); } } JsonString.Append( "]" ); } return JsonString.ToString(); } private DataTable getData() { DataTable dt = new DataTable(); dt.Columns.Add( "编号" , typeof (Int32)); dt.Columns.Add( "姓名" , typeof ( string )); dt.Columns.Add( "性别" , typeof ( string )); dt.Columns.Add( "学历" , typeof ( string )); dt.Rows.Add(1, "王超" , "男" , "本科" ); dt.Rows.Add(2, "周丽" , "女" , "专科" ); dt.Rows.Add(3, "李娟" , "女" , "专科" ); dt.Rows.Add(4, "杨明" , "男" , "硕士" ); dt.Rows.Add(5, "张德" , "男" , "本科" ); return dt; } } |
有兴趣可以试一下,希望对你有帮助。觉得不错就推荐一下吧,谢谢浏览!
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 2分钟学会 DeepSeek API,竟然比官方更好用!
· .NET 使用 DeepSeek R1 开发智能 AI 客户端
· 10亿数据,如何做迁移?
· 推荐几款开源且免费的 .NET MAUI 组件库
· c# 半导体/led行业 晶圆片WaferMap实现 map图实现入门篇