C#中DataTable转换为Json的⽅法汇总(三种⽅法)
在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动态添加⾏。代码如下:
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命名空间,如下:
using System.Text;
下⾯的代码将⽣成⼀个Json字符串,遍历DataTable的⾏和列,获取数据,添加到⼀个StringBuilder对象 JsonString,然后返回这个对象。
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("}");python json字符串转数组
}
else
{
JsonString.Append("},");
}
}
JsonString.Append("]");
}
return JsonString.ToString();
}
⽅法2:使⽤ JavaScriptSerializer.
⾸先我们添加System.Web.Script.Serialization命名空间,如下:
using System.Web.Script.Serialization;
JavaScriptSerializer这个类是由异步通信层内部使⽤来序列化和反序列化数据。如果序列化⼀个对象,就使⽤序列化⽅法。反序列化Json字符串,使⽤Deserialize或DeserializeObject⽅法。在这⾥,我们使⽤序列化⽅法得到Json格式的数据。代码以下:
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,再导⼊命名空间,代码如下:
using Newtonsoft.Json;
public string DataTableToJsonWithJsonNet(DataTable table)
{
string JsonString=string.Empty;
JsonString = JsonConvert.SerializeObject(table);
return JsonString;
}
效果图:
StringBuilder⽅法的全部代码:
using System;
using Susing 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;
}
}
以上所述是⼩编给⼤家介绍的C#中DataTable 转换为 Json的⽅法汇总(三种⽅法),希望对⼤家有所帮助,如果⼤家有任何疑问欢迎给我留⾔,⼩编会及时回复⼤家的,在此也⾮常感谢⼤家对⽹站的⽀持!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论