DataTable转Json(转载)
在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:List
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 +
"
");
}
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;
}
}
标签:
相关文章
-
无相关信息