欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

 
格式如下:

复制代码 代码如下:
{
    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#程序设计有所帮助。

上一篇:

下一篇: