当前位置: 移动技术网 > IT编程>开发语言>c# > C#将Json解析成DateTable的方法

C#将Json解析成DateTable的方法

2019年07月18日  | 移动技术网IT编程  | 我要评论

本文实例讲述了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#程序设计有所帮助。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网