zoukankan      html  css  js  c++  java
  • DataTable 转换成 Json的3种方法

    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 < stringobject >> parentRow = new List < Dictionary < stringobject >> (); 

           Dictionary < stringobject > childRow; 

           foreach(DataRow row in table.Rows)

           

               childRow = new Dictionary < stringobject > (); 

               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 + "<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;

        }

    }

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

  • 相关阅读:
    PHP 反射 ReflectionClass
    go-字符串生成数据库字段
    grpc类型
    ubuntu安装zookeeper集群
    ubuntu安装JDK
    zookeeper分布式读写锁
    golang利用gob序列化struct对象保存到本地(转载)
    golang手动管理内存(转载)
    类json格式字符串打印
    研二寒假---关于Qt&CV曲线算法问题
  • 原文地址:https://www.cnblogs.com/grj001/p/12224929.html
Copyright © 2011-2022 走看看