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动态添加行。代码如下:

 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命名空间,如下:

using System.Text; 

下边的代码将生成一个Json字符串,遍历DataTable的行和列,获取数据,添加到一个StringBuilder对象
JsonString,然后再次回到那个目标。

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命名空间,如下:

using System.Web.Script.Serialization;  

JavaScriptSerializer这么些类是由异步通讯层内部采纳来系列化和反体系化数据。借使种类化一个对象,就采纳连串化方法。反体系化Json字符串,使用Deserialize或DeserializeObject方法。在此间,我们采纳种类化方法拿到Json格式的数目。代码以下:

 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,再导入命名空间,代码如下:

using Newtonsoft.Json;

public string DataTableToJsonWithJsonNet(DataTable table) 
   {  
    string JsonString=string.Empty;  
    JsonString = JsonConvert.SerializeObject(table);  
    return JsonString;  
   }

  效果图:

图片 1

StringBuilder方法的全套代码:

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

 有趣味可以试一下,希望对您有赞助。觉得不错就引进一下吧,谢谢浏览!

 

相关文章