游客您好
第三方账号登陆
Lv.2 注册会员
1788号会员,14活跃度,2020/10/09 加入学习
  • 2发帖
  • 2主题
  • 0关注
  • 2粉丝
这个人很懒,什么也没有留下。
最新推荐更多

[C#开发] 3种DataTable 转换成 Json的方法

[复制链接]
后端小报 发表于 2020-10-12 21:27:49 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题
在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[j].ToString() + "\",");
                    }
                    else if (j == table.Columns.Count - 1)
                    {
                        JsonString.Append("\"" + table.Columns[j].ColumnName.ToString() + "\":" + "\"" + table.Rows[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;
   }



效果图:

image002.jpg

3种DataTable 转换成 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[j].ToString() + "\",");
                    }
                    else if (j == table.Columns.Count - 1)
                    {
                        JsonString.Append("\"" + table.Columns[j].ColumnName.ToString() + "\":" + "\"" + table.Rows[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;
    }
}


• 本内容来源互联网,如涉及版权问题请及时联系站长
• 为防止代码解析,除代码框内<>为正常,其余请重新替换<>尖括号

发布资源 快速回复 站点服务大厅 搜索 官方群