配色: 字号:
DataTable 转换成 Json的3种方法
2016-11-03 | 阅:  转:  |  分享 
  
DataTable转换成Json的3种方法



在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:List、DataTable转换为Json格式。特别在使用Extjs框架的时候,Ajax异步请求的数据格式就是Json。鉴于此,我今天来分享将DataTable转换成Json的3种方法。换句话说如何在ASP.NET将一个DataTable序列化为Json数组。或者如何从一个DataTable返回一个Json字符串。这篇文章将采用StringBuilder,JavaScriptSerializer和Json.NetDLL(Newtonsoft)这3种方法实现这一目标。



Json概述



JavaScriptObjectNotation(Json)是一种轻量级的数据交换格式。它基于ECMAScript的一个子集。这些特性使Json成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成(一般用于提升网络传输速率)。Json采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯,包括C、C++、C#、Java、JavaScript、Perl、Python等等。



这些特性使Json成为一种理想的数据交换语言。因此基于AJAX应用程序,Json已经成为一种用于数据交换的流行格式。总之,Json是一种存储和交换数据的语法,易于操作,也是除XML之外的不二之选。



步骤:



首先我们从MicrosoftSQLServer获取数据到DataTable,也可以给DataTable动态添加行。代码如下:

privateDataTablegetData()

{

DataTabledt=newDataTable();

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,"张德","男","本科");

returndt;

}

下面开始通过每一种方法实现DataTable转换成Json对象。



方法1:使用StringBuilder



这是Json样本数据的样子:{"姓名":"张三","年龄":"30"}。Json里用花括号保存对象,它可以包含多个名称/值对。所以使用StringBuilder我们可以创建一个类似的Json字符串。



由于要使用StringBuilder类,我们首先需要导入System.Text命名空间,如下:



1

usingSystem.Text;

下面的代码将生成一个Json字符串,遍历DataTable的行和列,获取数据,添加到一个StringBuilder对象JsonString,然后返回这个对象。

publicstringDataTableToJson(DataTabletable)

{

varJsonString=newStringBuilder();

if(table.Rows.Count>0)

{

JsonString.Append("[");

for(inti=0;i
{

JsonString.Append("{");

for(intj=0;j
{

if(j
{

JsonString.Append("\""+table.Columns[j].ColumnName.ToString()+"\":"+"\""+table.Rows[i][j].ToString()+"\",");

}

elseif(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("]");

}

returnJsonString.ToString();

}

方法2:使用JavaScriptSerializer.



首先我们添加System.Web.Script.Serialization命名空间,如下:



1

usingSystem.Web.Script.Serialization;

JavaScriptSerializer这个类是由异步通信层内部使用来序列化和反序列化数据。如果序列化一个对象,就使用序列化方法。反序列化Json字符串,使用Deserialize或DeserializeObject方法。在这里,我们使用序列化方法得到Json格式的数据。代码以下:

publicstringDataTableToJsonWithJavaScriptSerializer(DataTabletable)

{

JavaScriptSerializerjsSerializer=newJavaScriptSerializer();

List>parentRow=newList>();

DictionarychildRow;

foreach(DataRowrowintable.Rows)

{

childRow=newDictionary();

foreach(DataColumncolintable.Columns)

{

childRow.Add(col.ColumnName,row[col]);

}

parentRow.Add(childRow);

}

returnjsSerializer.Serialize(parentRow);

}

方法3:使用Json.NetDLL(Newtonsoft)。



这个方法中要添加Json.NetDLL引用,我们可以从Newtonsoft下载Json.NetDLL,再导入命名空间,代码如下:

usingNewtonsoft.Json;



publicstringDataTableToJsonWithJsonNet(DataTabletable)

{

stringJsonString=string.Empty;

JsonString=JsonConvert.SerializeObject(table);

returnwww.baiyuewang.netJsonString;

}

效果图:







StringBuilder方法的全部代码:



usingSystem;

usingSystem.Text;

usingSystem.Data;



publicpartialclassDefault2:System.Web.UI.Page

{

privatestringsasss;



protectedvoidPage_Load(objectsender,EventArgse)

{

DataTabletable=getData();

sasss=DataTableToJson(table);



Response.Write(sasss+"
");



}



publicstringDataTableToJson(DataTabletable)

{

varJsonString=newStringBuilder();

if(table.Rows.Count>0)

{

JsonString.Append("[");

for(inti=0;i
{

JsonString.Append("{");

for(intj=0;j
{

if(j
{

JsonString.Append("\""+table.Columns[j].ColumnName.ToString()+"\":"+"\""+table.Rows[i][j].ToString()+"\",");

}

elseif(j==table.Columns.Count-1)

{

JsonString.Append("\""+table.Columns[j].ColumnName.ToString()+"\":"+"\""+table.Rows[i][j].Twww.wang027.comoString()+"\"");

}

}

if(i==table.Rows.Count-1)

{

JsonString.Append("}");

}

else

{

JsonString.Append("},");

}

}

JsonString.Append("]");

}

returnJsonString.ToString();

}



privateDataTablegetData()

{

DataTabledt=newDataTable();

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,"张德","男","本科");

returndt;

}

}

献花(0)
+1
(本文系thedust79首藏)