C#中DataTable 转换为 Json的方法汇总(三种方法)

C#中DataTable 转换为 Json的方法汇总(三种方法),第1张

概述在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:List<T>、DataTable转换为Json格式。特别在使用Extjs框架的时候,Ajax异步请求的数据格式就是Json。鉴于此

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

效果图:

@H_404_73@

StringBuilder方法的全部代码:

using System;using Susing System.Data;public partial class Default2 : System.Web.UI.Pageprivate 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() + "\",");}}JsonString.Append("]");}return JsonString.ToString(); }private Datatable getData(){Datatable dt = new Datatable();dt.Columns.Add("编号","本科");return dt;}}

以上所述是小编给大家介绍的C#中Datatable 转换为 Json的方法汇总(三种方法),希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的,在此也非常感谢大家对编程小技巧网站的支持!

总结

以上是内存溢出为你收集整理的C#中DataTable 转换为 Json的方法汇总(三种方法)全部内容,希望文章能够帮你解决C#中DataTable 转换为 Json的方法汇总(三种方法)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1257075.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-07
下一篇 2022-06-07

发表评论

登录后才能评论

评论列表(0条)

保存