C#将Json解析成DateTable的方法
作者:shichen2014 时间:2022-11-19 20:10:42
本文实例讲述了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,方法
0
投稿
猜你喜欢
利用javaFX实现移动一个小球的示例代码
2022-06-18 19:04:51
Android 两个Fragment之间传递数据实例详解
2022-06-23 19:30:09
java使用JNA(Java Native Access)调用dll的方法
2022-02-06 09:27:34
Java背包问题求解实例代码
2023-10-05 06:20:33
Dagger2 Android依赖注入学习笔记
2021-11-27 17:15:54
Android XRecyclerView实现多条目加载
2021-10-15 07:32:21
详解Java8新特性Stream之list转map及问题解决
2021-06-12 05:45:06
c# 利用易福门振动模块VSE002采集振动数据的方法
2022-10-13 00:12:25
仿ios状态栏颜色和标题栏颜色一致的实例代码
2023-08-20 02:17:45
Android 音乐播放器的开发实例详解
2023-12-07 17:53:10
使用spring通过aop获取方法参数和参数值
2022-06-04 16:28:33
swagger添加权限验证保证API(接口)安全性(两种方法)
2023-11-27 18:58:33
C#中累加器函数Aggregate用法实例
2023-03-21 10:28:30
springboot 同时启用http/https的配置方法
2023-06-22 12:04:12
springcloud中RabbitMQ死信队列与延迟交换机实现方法
2023-05-04 04:25:54
android LabelView实现标签云效果
2021-09-24 18:01:44
C#装箱和拆箱操作实例分析
2021-10-25 13:17:36
Dubbo retries 超时重试机制的问题原因分析及解决方案
2023-11-29 08:22:38
简述Java List去重五种方法
2022-02-28 03:17:13
Android RecyclerView缓存复用原理解析
2022-04-29 10:51:03