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; ​

​}​


  效果图:

DataTable 转换成 Json的3种方法_json

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;​

​}​

​}​


 有兴趣可以试一下,希望对你有帮助。觉得不错就推荐一下吧,谢谢浏览!