手机
当前位置:查字典教程网 >编程开发 >C#教程 >C#实现将json转换为DataTable的方法
C#实现将json转换为DataTable的方法
摘要:本文实例讲述了C#实现将json转换为DataTable的方法。分享给大家供大家参考。具体实现方法如下:复制代码代码如下:#region将j...

本文实例讲述了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的方法】相关文章:

c# 如何将RadioButton与DataTable数据进行绑定

C#实现对AES加密和解密的方法

C#中Array与ArrayList用法及转换的方法

C#中HashTable的定义与使用方法

C# 去除首尾字符或字符串的方法

C#访问PostGreSQL数据库的方法

C#操作注册表的方法

C# IP地址与整数之间转换的具体方法

C# 将字节流转换为图片的实例方法

C#读写文件的方法汇总

精品推荐
分类导航