C#实现将json转换为DataTable的方法

本文实例讲述了C#实现将json转换为DataTable的方法。分享给大家供大家参考。具体实现方法如下:

代码如下:

#region 将json转换为DataTable

/// <summary>

/// 将json转换为DataTable

/// </summary>

/// <param name=”strJson”>得到的json</param>

/// <returns></returns>

private DataTable JsonToDataTable(string strJson)

{

//转换json格式

strJson = strJson.Replace(“,\””, “*\””).Replace(“\”:”, “\”#”).ToString();

//取出表名

var rg = new Regex(@”(?<={)[^:]+(?=:\[)”, RegexOptions.IgnoreCase);

string strName = rg.Match(strJson).Value;

DataTable tb = null;

//去除表名

strJson = strJson.Substring(strJson.IndexOf(“[“) + 1);

strJson = strJson.Substring(0, strJson.IndexOf(“]”));

//获取数据

rg = new Regex(@”(?<={)[^}]+(?=})”);

MatchCollection mc = rg.Matches(strJson);

for (int i = 0; i < mc.Count; i++)

{

string strRow = mc[i].Value;

string[] strRows = strRow.Split(‘*’);

//创建表

if (tb == null)

{

tb = new DataTable();

tb.TableName = strName;

foreach (string str in strRows)

{

var dc = new DataColumn();

string[] strCell = str.Split(‘#’);

if (strCell[0].Substring(0, 1) == “\””)

{

int a = strCell[0].Length;

dc.ColumnName = strCell[0].Substring(1, a – 2);

}

else

{

dc.ColumnName = strCell[0];

}

tb.Columns.Add(dc);

}

tb.AcceptChanges();

}

//增加内容

DataRow dr = tb.NewRow();

for (int r = 0; r < strRows.Length; r++)

{

dr[r] = strRows[r].Split(‘#’)[1].Trim().Replace(“,”, “,”).Replace(“:”, “:”).Replace(“\””, “”);

}

tb.Rows.Add(dr);

tb.AcceptChanges();

}

return tb;

}

#endregion

希望本文所述对大家的C#程序设计有所帮助。

除声明外,跑步客文章均为原创,转载请以链接形式标明本文地址
  C#实现将json转换为DataTable的方法

本文地址:  http://www.paobuke.com/develop/c-develop/pbk23119.html

相关内容

C#使用NPOI导入Excel的方法详解

é?è?àí?aC? 7.0?Dμ?Tupleì?D?

C#编程自学之类和对象

C#同步网络时间的方法实例详解


c#桥接模式(bridge结构模式)用法实例

C#子线程更新UI控件的方法实例总结

C#调用SQL语句时乘号的用法

C#入门之checked和unchecked的区别实例解析

时间: 2024-10-08 13:00:26

C#实现将json转换为DataTable的方法的相关文章

c# 将json转换为DataTable

/// <summary> /// 将json转换为DataTable /// </summary> /// <param name="strJson">得到的json</param> /// <returns></returns> public static DataTable JsonToDataTable(string strJson) { //转换json格式 strJson = strJson.Repla

c#常用的Datable转换为json,以及json转换为DataTable操作方法

#region  DataTable 转换为Json字符串实例方法/// <summary>/// GetClassTypeJosn 的摘要说明/// </summary>public class GetClassTypeJosn : IHttpHandler{    /// <summary>    /// 文件名:DataTable 和Json 字符串互转    /// 版权所有:Copyright (C) Create Family Wealth liangjw 

将list转换为datatable的方法

public static DataTable CopyToDataTable<T>(this IEnumerable<T> array) { var ret = new DataTable(); foreach (PropertyDescriptor dp in TypeDescriptor.GetProperties(typeof(T))) ret.Columns.Add(dp.Name); foreach (T item in array) { var Row = ret.N

json转datatable(正则表达式的方法)

/// <summary> /// 将json转换为DataTable /// </summary> /// <param name="strJson">得到的json</param> /// <returns></returns> private DataTable JsonToDataTable(string strJson) { //转换json格式 strJson = strJson.Replace(&qu

Json 字符串 转换为 DataTable数据集合

/// <summary> /// 将json转换为DataTable /// </summary> /// <param name="strJson">得到的json</param> /// <returns></returns> private DataTable JsonToDataTable(string strJson) { //转换json格式 strJson = strJson.Replace(&qu

反射 DataTable拓展方法 转实体对象、实体集合、JSON

Mapper类 using System; using System.Collections.Generic; using System.Data; using System.Globalization; using System.Linq; using System.Reflection; using System.Text; using System.Threading.Tasks; namespace CommonHelper { public class Mapper { public

DataTable 转换成 Json的3种方法

在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:List<T>.DataTable转换为Json格式.特别在使用Extjs框架的时候,Ajax异步请求的数据格式就是Json.鉴于此,我今天来分享将DataTable 转换成 Json的3种方法.换句话说如何在ASP.NET将一个DataTable序列化为 Json数组.或者如何从一个DataTable返回一个Json字符串.这篇文章将采用StringBuilder,JavaScriptSeri

PCB MS SQL 存储过程(CLR) 实现Json转DataTable表的方法

一.准备需转为DataTable的json字符串 原json字符串数据 [{"TechName":"ECN","TechNo":"EC_01","id":"1"},{"TechName":"流程指示","TechNo":"PI_01","id":"2"},{"

jquery解析json格式数据的方法(对象、字符串)

相关函数 函数 描述 JSON.parse() 用于将一个 JSON 字符串转换为 JavaScript 对象. JSON.stringify() 用于将 JavaScript 值转换为 JSON 字符串. //data为字符串类型 则要将字符串类型转换成json数据类型 var jsondatas=eval("("+data+")"); 本文实例讲述了jquery解析json格式数据的方法.分享给大家供大家参考,具体如下: json数据是我们常用的一种小型的数据实