在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:List、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;

}

StringBuilder方法的全部代码:

using System;

using Susing 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;

}

}

posted on 2020-05-15 10:49 青蛙學堂 阅读(428) 评论(0)  编辑 收藏 引用 所属分类: c#

badatatable转成json_C# DataTable 转换成JSON数据 三种方法相关推荐

  1. Dataset/Datatable/Datarow转Json的一种方法

    //以下三句為轉Dataset/Datatable為Json格式的一般方法. System.Web.Script.Serialization.JavaScriptSerializer serial = ...

  2. 【Pandas】datetime转换到string的三种方法

    建立一个datetime.now().date() from datetime import datetime, timedelta datetime.now().date() datetime.no ...

  3. java对象转换String类型的三种方法

    **一.采用Object.toString() **toString方法是java.lang.Object对象的一个public方法.在java中任何对象都会继承Object对象,所以一般来说任何对象 ...

  4. 如何把音频转换成文本?不妨来试一下这三种方法吧

    在教育培训领域中,有时需要对授课内容进行记录和整理.使用音频转化为文字的方法可以帮助学生更好地理解老师的授课内容,从而便于复习和总结.那么怎样将音频转化为文字呢?今天我来给大家分享几个非常好用的音频转 ...

  5. 小程序图片转换Base64格式的三种方法

    一.使用小程序自带的网络请求 1.wx.request() 这种方式适合网络https路径图片,但无法解析wxfile://xxxx导致转化报错 image2Base64(imgUrl) {retur ...

  6. 怎么转换CAD图纸格式?三种方法帮你搞定CAD转PDF格式操作!

    对于许多小伙伴们而言,对于CAD的了解在不断的加深,而我们的制图水平随着不断的时间的累积也越来越厉害,CAD转PDF格式这种简单的图纸格式转阿虎操作自然不在话下,但是对于许多刚刚开始接触CAD的小伙伴 ...

  7. badatatable转成json_DataTable 转换成 Json的3种方法 | YuXi

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

  8. C#将DataTable转换成list的方法

    本文实例讲述了C#将DataTable转换成list及数据分页的方法.分享给大家供大家参考.具体如下: /// <summary> /// 酒店评论列表-分页 /// </summa ...

  9. java 把map转换成json_map转换成JSON的3种方法

    1 json-lib net.sf.json-lib json-lib 2.4 jdk15 import java.util.HashMap; import java.util.Map; import ...

最新文章

  1. 深入浅出ShellExecute
  2. ODBC + WIN32 API 访问MYSQL 数据库实现简单QQ用户注册和登录 的代码分析
  3. 快的打车联合创始人兼技术副总裁闻诚:CTO要有“334”能力
  4. springboot 获取配置文件中的值_Spring Boot面试必问(亲测)
  5. HD 1176 免费馅饼 (DP)
  6. CSS的clear去除清除浮动元素
  7. python列表代码_8种高级的Python列表使用技巧,都给你整理好啦(附实操代码)...
  8. 华为双11发 20 亿奖金!?
  9. 【Python】SyntaxError: Non-ASCII character ‘\xe8‘ in file main.py on line 7, but no encoding declared;
  10. 如何给企业选择一款ERP系统
  11. 解决在极光推送的时候会出现一个 JPush提示:缺少统计代码
  12. tensorflow的GPU使用--Python
  13. CVPR2020-深度图超分辨率DSR新方法| Channel Attention based Iterative Residual Learning for Depth Map SR
  14. mysql数据库软件 国产_国产数据库发展情况如何?
  15. android+蓝牙手柄+驱动+win10,jetion手柄驱动万能版
  16. CCF CSP 公共钥匙盒
  17. GreenDao的简单学习(附带demo源码)
  18. 轻松认识HTTP协议的概念和工作原理
  19. php模拟QQ登录获得skey码,php模拟qq登录代码
  20. 点集拓扑学思维导图(附pdf源文档)

热门文章

  1. 基于深度卷积神经网络进行人脸识别的原理是什么?
  2. C++ dll 类型与 C#类型对应关系
  3. ios 静态库冲突的解决办法
  4. 目标跟踪算法五:MDNet: Learning Multi-Domain Convolutional Neural Networks for Visual Tracking
  5. 渗透知识-linux基础命令
  6. c语言循环设计思想结构,C语言程序设计_05循环结构程序设计讲述.pptx
  7. directshow c++ 设置 曝光_DirectShow 接口访问相机参数设置方法
  8. java集合的加减_在JAVA中,对List集合的加减操作
  9. 阿里云的java规范_阿里JAVA开发强制要求的15条并发处理规范,切记
  10. Selenium之鼠标和键盘操作及扩展