zoukankan      html  css  js  c++  java
  • 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动态添加行。代码如下:

    [csharp] view plain copy
     
    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命名空间,如下:

    [csharp] view plain copy
     
    1. using System.Text;  

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

    [csharp] view plain copy
     
    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命名空间,如下:

    [csharp] view plain copy
     
    1. using System.Web.Script.Serialization;  


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

    [csharp] view plain copy
     
    1. public string DataTableToJsonWithJavaScriptSerializer(DataTable table)  
    2.    {   
    3.        JavaScriptSerializer jsSerializer = new JavaScriptSerializer();   
    4.        List < Dictionary < string, object >> parentRow = new List < Dictionary < string, object >> ();   
    5.        Dictionary < string, object > childRow;   
    6.        foreach(DataRow row in table.Rows)  
    7.        {   
    8.            childRow = new Dictionary < string, object > ();   
    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,再导入命名空间,代码如下:

    [csharp] view plain copy
     
    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.    }  

    效果图:

    StringBuilder方法的全部代码:

    [csharp] view plain copy
     
      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. }  
  • 相关阅读:
    python面试题总结(1)
    python数据结构与算法之算法和算法分析
    python数据结构与算法之问题求解实例
    python数据结构与算法之问题求解
    导航栏挡住View
    coredata
    SVN
    mac 上用到的数据库软件
    开博感言
    九 、循环队列的java实现
  • 原文地址:https://www.cnblogs.com/ChineseMoonGod/p/7000526.html
Copyright © 2011-2022 走看看