C#将Json解析成DateTable的方法

Pandora ·
更新时间:2024-09-20
· 613 次阅读

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

您可能感兴趣的文章:C#解析json文件的实现代码asp.net(C#)解析Json的类代码C#解析JSON实例c#版json数据解析示例分享C#解析json字符串总是多出双引号的原因分析及解决办法C#使用LitJson解析JSON的示例代码详解C#对XML、JSON等格式的解析c#处理3种json数据的实例C#实现json的序列化和反序列化实例代码C# XML与Json之间相互转换实例详解C#实现任意数据类型转成json格式输出C#实现json格式数据解析功能的方法详解



json解析 JSON C# 方法

需要 登录 后方可回复, 如果你还没有账号请 注册新账号
相关文章