C#将Json解析成DateTable的方法
程序员文章站
2023-12-13 12:26:10
本文实例讲述了c#将json解析成datetable的方法。分享给大家供大家参考。具体实现方法如下:
复制代码 代码如下:#region 将 json 解析成 datet...
本文实例讲述了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
/// 将 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
}
]
}
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: 名称
}
]
{
code: metadataid,
name: metadataid
},
{
code: metadatacode,
name: 编号
},
{
code: solutionname,
name: 名称
}
]
希望本文所述对大家的c#程序设计有所帮助。