时间:2021-05-20
本文实例讲述了C#将Json解析成DateTable的方法。分享给大家供大家参考。具体实现方法如下:
复制代码 代码如下:#region 将 Json 解析成 DateTable ///
/// 将 Json 解析成 DateTable。
/// Json 数据格式如: ///
{table:[{column1:1,column2:2,column3:3},{column1:1,column2:2,column3:3}]}
///
///要解析的 Json 字符串
/// 返回 DateTable public DataTable JsonToDataTable(string strJson)
{
//
取出表名 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(':');
dc.ColumnName = strCell[0].Replace(, );
tb.Columns.Add(dc); }
tb.AcceptChanges();
} // 增加内容 DataRow dr = tb.NewRow();
for (int j = 0; j < strRows.Length; j++)
{ dr[j] = strRows[j].Split(':')[1].Replace(,
);
} tb.Rows.Add(dr);
tb.AcceptChanges();
}
return tb; }
#endregion
格式如下:
复制代码 代码如下:{
table: [
{
column1: 1,
column2: 2,
column3: 3
},
{
column1: 1,
column2: 2,
column3: 3
}
]
}
例如:
复制代码 代码如下:[{Code:MetaDataId,Name:MetaDataId},{Code:MetadataCode,Name:编号},{Code:SolutionName,Name:名称}]
格式化后:
复制代码 代码如下:[
{
Code: MetaDataId,
Name: MetaDataId
},
{
Code: MetadataCode,
Name: 编号
},
{
Code: SolutionName,
Name: 名称
}
]
希望本文所述对大家的C#程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文以实例形式讲述了C#解析JSON的方法,C#封装了对XML和JSON解析的类库,使用相当方便!具体用法如下:1.主要用到的类:主要用到了JavaScript
本文实例讲述了C#实现json格式数据解析功能的方法。分享给大家供大家参考,具体如下:来写写json的解析吧首先添加web引用System.Web.Extens
C#中已经有JavaScriptSerializer类可以将json数据给反序列化为对象//////JSON文本转对象,泛型方法//////类型///JSON文
作者在原文中说明了通过C#调用Javascript来解析Json字符串的方法。代码如下:复制代码代码如下:usingMicrosoft.JScript;usin
之前写过一篇关于JSON的介绍文章,里面谈到了JSON的解析。我们都知道,高级浏览器可以用JSON.parse()API将一个JSON字符串解析成JSON数据,