DataTable 转换成 Json的3种方法

  • A+
所属分类:ASP.NET

DataTable 转换成 Json的3种方法
在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:ListDataTable转换为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动态添加行。代码如下:

步骤:

首先我们从Microsoft SQL Server的获取数据到数据表,也可以给数据表动态添加行代码如下:

  1. private DataTable getData()    
  2.    {    
  3.        DataTable dt = new DataTable();    
  4.        dt.Columns.Add("编号"typeof(Int32));    
  5.        dt.Columns.Add("姓名"typeof(string));    
  6.        dt.Columns.Add("性别"typeof(string));    
  7.        dt.Columns.Add("学历"typeof(string));    
  8.        dt.Rows.Add(1, "王超""男""本科");    
  9.        dt.Rows.Add(2, "周丽""女""专科");    
  10.        dt.Rows.Add(3, "李娟""女""专科");    
  11.        dt.Rows.Add(4, "杨明""男""硕士");    
  12.        dt.Rows.Add(5, "张德""男""本科");    
  13.        return dt;    
  14.    }    

下面开始通过每一种方法实现DataTable转换成 Json 对象。

方法1:使用StringBuilder

这是Json样本数据的样子: {"姓名 ":"张三", "年龄":"30"}。Json里用花括号保存对象,它可以包含多个名称/值对。所以使用StringBuilder我们可以创建一个类似的Json字符串。

由于要使用StringBuilder类,我们首先需要导入System.Text命名空间,如下:

  1. using System.Text;   

下面的代码将生成一个Json字符串,遍历DataTable的行和列,获取数据,添加到一个StringBuilder对象 JsonString,然后返回这个对象。

  1. public string DataTableToJson(DataTable table)    
  2.     {    
  3.         var JsonString = new StringBuilder();    
  4.         if (table.Rows.Count > 0)    
  5.         {    
  6.             JsonString.Append("[");    
  7.             for (int i = 0; i < table.Rows.Count; i++)    
  8.             {    
  9.                 JsonString.Append("{");    
  10.                 for (int j = 0; j < table.Columns.Count; j++)    
  11.                 {    
  12.                     if (j < table.Columns.Count - 1)    
  13.                     {    
  14.                         JsonString.Append("\"" + table.Columns[j].ColumnName.ToString() + "\":" + "\"" + table.Rows[i][j].ToString() + "\",");    
  15.                     }    
  16.                     else if (j == table.Columns.Count - 1)    
  17.                     {    
  18.                         JsonString.Append("\"" + table.Columns[j].ColumnName.ToString() + "\":" + "\"" + table.Rows[i][j].ToString() + "\"");    
  19.                     }    
  20.                 }    
  21.                 if (i == table.Rows.Count - 1)    
  22.                 {    
  23.                     JsonString.Append("}");    
  24.                 }    
  25.                 else    
  26.                 {    
  27.                     JsonString.Append("},");    
  28.                 }    
  29.             }    
  30.             JsonString.Append("]");    
  31.         }    
  32.         return JsonString.ToString();      
  33.     }    

方法2:使用 JavaScriptSerializer.

首先我们添加System.Web.Script.Serialization命名空间,如下:

  1. using System.Web.Script.Serialization;    

JavaScriptSerializer这个类是由异步通信层内部使用来序列化和反序列化数据。如果序列化一个对象,就使用序列化方法。反序列化Json字符串,使用Deserialize或DeserializeObject方法。在这里,我们使用序列化方法得到Json格式的数据。代码以下:

  1. public string DataTableToJsonWithJavaScriptSerializer(DataTable table)    
  2.    {     
  3.        JavaScriptSerializer jsSerializer = new JavaScriptSerializer();     
  4.        List < Dictionary < stringobject >> parentRow = new List < Dictionary < stringobject >> ();     
  5.        Dictionary < stringobject > childRow;     
  6.        foreach(DataRow row in table.Rows)    
  7.        {     
  8.            childRow = new Dictionary < stringobject > ();     
  9.            foreach(DataColumn col in table.Columns)    
  10.            {     
  11.                childRow.Add(col.ColumnName, row[col]);     
  12.            }     
  13.            parentRow.Add(childRow);     
  14.        }     
  15.        return jsSerializer.Serialize(parentRow);     
  16.    }   

方法3:使用Json.Net DLL (Newtonsoft)。

这个方法中要添加Json.Net DLL引用,我们可以从Newtonsoft下载Json.Net DLL,再导入命名空间,代码如下:

  1. using Newtonsoft.Json;    
  2.      
  3. public string DataTableToJsonWithJsonNet(DataTable table)    
  4.    {     
  5.     string JsonString=string.Empty;     
  6.     JsonString = JsonConvert.SerializeObject(table);     
  7.     return JsonString;     
  8.    }    

效果图:
DataTable 转换成 Json的3种方法
StringBuilder方法的全部代码:

  1. using System;    
  2. using System.Text;    
  3. using System.Data;    
  4.      
  5. public partial class Default2 : System.Web.UI.Page    
  6. {    
  7.     private string sasss;    
  8.         
  9.     protected void Page_Load(object sender, EventArgs e)    
  10.     {    
  11.         DataTable table = getData();    
  12.         sasss = DataTableToJson(table);    
  13.      
  14.         Response.Write(sasss + "<br/>");    
  15.      
  16.     }    
  17.          
  18.     public string DataTableToJson(DataTable table)    
  19.     {    
  20.         var JsonString = new StringBuilder();    
  21.         if (table.Rows.Count > 0)    
  22.         {    
  23.             JsonString.Append("[");    
  24.             for (int i = 0; i < table.Rows.Count; i++)    
  25.             {    
  26.                 JsonString.Append("{");    
  27.                 for (int j = 0; j < table.Columns.Count; j++)    
  28.                 {    
  29.                     if (j < table.Columns.Count - 1)    
  30.                     {    
  31.                         JsonString.Append("\"" + table.Columns[j].ColumnName.ToString() + "\":" + "\"" + table.Rows[i][j].ToString() + "\",");    
  32.                     }    
  33.                     else if (j == table.Columns.Count - 1)    
  34.                     {    
  35.                         JsonString.Append("\"" + table.Columns[j].ColumnName.ToString() + "\":" + "\"" + table.Rows[i][j].ToString() + "\"");    
  36.                     }    
  37.                 }    
  38.                 if (i == table.Rows.Count - 1)    
  39.                 {    
  40.                     JsonString.Append("}");    
  41.                 }    
  42.                 else    
  43.                 {    
  44.                     JsonString.Append("},");    
  45.                 }    
  46.             }    
  47.             JsonString.Append("]");    
  48.         }    
  49.         return JsonString.ToString();      
  50.     }    
  51.      
  52.     private DataTable getData()    
  53.     {    
  54.         DataTable dt = new DataTable();    
  55.         dt.Columns.Add("编号"typeof(Int32));    
  56.         dt.Columns.Add("姓名"typeof(string));    
  57.         dt.Columns.Add("性别"typeof(string));    
  58.         dt.Columns.Add("学历"typeof(string));    
  59.         dt.Rows.Add(1, "王超""男""本科");    
  60.         dt.Rows.Add(2, "周丽""女""专科");    
  61.         dt.Rows.Add(3, "李娟""女""专科");    
  62.         dt.Rows.Add(4, "杨明""男""硕士");    
  63.         dt.Rows.Add(5, "张德""男""本科");    
  64.         return dt;    
  65.     }    
  66. }    
钰玺

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: