博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
DataTable 转换成 Json的3种方法
阅读量:5124 次
发布时间:2019-06-13

本文共 5926 字,大约阅读时间需要 19 分钟。

在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引用,我们可以从下载Json.Net DLL,再导入命名空间,代码如下:

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

  效果图:

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

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

 

转载于:https://www.cnblogs.com/Yesi/p/6022954.html

你可能感兴趣的文章
HTML元素定义 ID,Class,Style的优先级
查看>>
构造者模式
查看>>
http和https的区别
查看>>
Hbuild在线云ios打包失败,提示BuildConfigure Failed 31013 App Store 图标 未找到 解决方法...
查看>>
找到树中指定id的所有父节点
查看>>
今天新开通了博客
查看>>
AS3优化性能笔记二
查看>>
ElasticSearch(站内搜索)
查看>>
4----COM:a Generative Model for group recommendation(组推荐的一种生成模型)
查看>>
UVA 11137 - Ingenuous Cubrency
查看>>
js阻止事件冒泡的两种方法
查看>>
Java异常抛出
查看>>
[SQL Server 系] T-SQL数据库的创建与修改
查看>>
74HC164应用
查看>>
变量声明和定义的关系
查看>>
Wpf 之Canvas介绍
查看>>
linux history
查看>>
jQuery on(),live(),trigger()
查看>>
Python2.7 urlparse
查看>>
sencha touch在华为emotion ui 2.0自带浏览器中圆角溢出的bug
查看>>