首先我们看看 Newtonsoft.Json.JsonConvert 是怎么完成的:

           DataTable table = new DataTable();
table.Columns.Add("id");
table.Columns.Add("name");
table.Columns.Add("url");
table.Rows.Add("", "zhengdjin", "http://blog.csdn.net/zhengdjin");
table.Rows.Add("", "生活信息网", "http://www.naoqiu.com"); //Newtonsoft.Json api:
//序列化
string api_s= Newtonsoft.Json.JsonConvert.SerializeObject(table);
Console.WriteLine(api_s);
//反序列化
DataTable api_Table = Newtonsoft.Json.JsonConvert.DeserializeObject(api_s, typeof(DataTable)) as DataTable;
Console.ReadLine();

实现的方式相当简单,微软都帮我处理掉那些繁杂的操作,那我们来还原将DataTable转换为Json格式的情景:

我为了做更多的扩展,首先创建一个json基类代码如下:

  /// <summary>
/// json基类
/// </summary>
public abstract class IJson<T>
{
/// <summary>
/// 行信息区域块表示方式
/// </summary>
private string _rowInfo = "{}";
/// <summary>
/// 行分割字符
/// </summary>
private char _rowSp = ',';
/// <summary>
/// 列分割字符
/// </summary>
private char _columnSp = ','; /// <summary>
/// 行分割字符
/// </summary>
public char RowSplit {
get { return _rowSp; }
set { _rowSp = value; }
}
/// <summary>
/// 列分割字符
/// </summary>
public char ColumnSplit {
get { return _columnSp; }
set { _columnSp = value; }
}
/// <summary>
/// 行信息区域块表示方式
/// </summary>
public string RowInfo
{
get { return _rowInfo; }
set { _rowInfo = value; }
} /// <summary>
/// 默认json转化参数格式
/// </summary>
public IJson() : this(',', ',', "{}") { } public IJson(char rSplit, char cSplit, string rInfo)
{
this._rowSp=rSplit;
this._columnSp = cSplit;
this._rowInfo = rInfo;
} /// <summary>
/// 转化为json对象
/// </summary>
/// <typeparam name="T">对象类型</typeparam>
/// <param name="t">参数</param>
/// <returns></returns>
public abstract string toJson<T>(T t); /// <summary>
/// jsaon转化对象
/// </summary>
/// <param name="json">jsaon字符</param>
/// <returns>对象</returns>
public abstract T toObject(string json);
}

接下来定义一个JsontoDataTable 继承json基类,然后实现 toJson<T>(T t) 将dataTable转换为json

     /// <summary>
/// dataTable转化为json对象
/// </summary>
/// <typeparam name="T">参数类型</typeparam>
/// <param name="t">参数</param>
/// <returns></returns>
public override string toJson<T>(T t)
{
DataTable table = t as DataTable;
if (table == null) return "";
if (RowInfo.Length != ) throw new NotImplementedException("行信息区域块表示方式格式不正确");
StringBuilder jsonBuilder = new StringBuilder();
jsonBuilder.Append(table.TableName+":[");
string head = "";
int i = ;
foreach (DataColumn dc in table.Columns){
head += dc.ColumnName + ":" + (dc.DataType == typeof(int) || dc.DataType == typeof(decimal) ?
"{" + i++.ToString() + "}" : "\"{" + i++.ToString() + "}\"") + ColumnSplit.ToString();
}
head = head.TrimEnd(ColumnSplit);
foreach (DataRow dr in table.Rows){
jsonBuilder.Append(RowInfo[].ToString());
jsonBuilder.AppendFormat(head, dr.ItemArray.ToArraybySpecial());
jsonBuilder.Append(RowInfo[].ToString() + RowSplit.ToString());
}
return jsonBuilder.ToString().Trim(RowSplit) + "]";
} 到这里已经完成了DataTable转换为json ,现在还差个将json转化为DataTable,这个方法相对难度比DataTable转换json稍微。实现这个方法过程中我们得使用正则表达式来获取数据(可参考asp.net如何加快页面加载(三)——浅谈正则应用)。      /// <summary>
/// json转化为DataTable
/// </summary>
/// <param name="json">json变量</param>
/// <returns>DataTable</returns>
public override DataTable toObject(string json)
{
string pattern_row = @"(" + RowInfo[] + "(.|\n)*?(" + RowInfo[] + RowSplit +
@")|" + RowInfo[] + "(.|\n)*?(" + RowInfo[] + @"\]))";
//获取行记录
MatchCollection matches = Regex.Matches(json, pattern_row);
if (matches.Count == ) return null;
//获取列名
MatchCollection matches_columns = Regex.Matches(matches[].Value, "(?<=[" + RowInfo[].ToString() + ColumnSplit.ToString() + @"])[^\:]+");
DataTable table = new DataTable();
//绑定列名
foreach (Match m in matches_columns) {
table.Columns.Add(m.Value);
}
//绑定数据
DataRow dr;
string value;
foreach (Match m in matches) {
dr = table.NewRow();
foreach (Match mc in matches_columns) {
value = Regex.Match(m.Value, "(?<=[" + RowInfo[].ToString() + ColumnSplit.ToString() + "]+" + mc.Value + @"\:)[\d\.]+").Value;
if (value == "") {
value = Regex.Match(m.Value, "(?<=[" + RowInfo[].ToString() + ColumnSplit.ToString() + "]+" +
mc.Value + @"\:\"")(.|\n)*?\""[" + ColumnSplit.ToString() + RowInfo[].ToString() + "]").Value;
}
dr[mc.Value] = Regex.Replace(value, "\"[" + ColumnSplit.ToString() + RowInfo[].ToString() + "]", "").toDesSpecial();
}
table.Rows.Add(dr);
}
return table;
}

到这里完成了json 与DataTable互转的功能。

json与DataTable相互转换的更多相关文章

  1. DateTable与List<T>相互转换 及JSON与DataTable(DataSet)相互转化

    http://www.360doc.com/content/13/0712/09/10504424_299336674.shtml Linq处理List数据 http://blog.163.com/l ...

  2. #region Json转DataTable

    #region  Json转DataTable        private DataTable Json2Dtb(string json)        {            JavaScrip ...

  3. php中 xml json 数组 之间相互转换

    php中 xml json  数组 之间相互转换 1 数组转json $result = array( 'status' =>$status, 'message'=>$message, ' ...

  4. C#Json转DataTable

    需求:有一个log文件,需要整理成Excel,日志文件里面的数据都是json字符串 思路是,把Json字符串转换成DataTable,然后导出到Excel 在网上找了一些资料,整理了以下三种类型的Js ...

  5. json转datatable(正则表达式的方法)

    /// <summary> /// 将json转换为DataTable /// </summary> /// <param name="strJson" ...

  6. DataTable转Json,Json转DataTable

    // 页面加载时 /// </summary> /// <param name="sender"></param> /// <param ...

  7. c# 将json转换为DataTable

    /// <summary> /// 将json转换为DataTable /// </summary> /// <param name="strJson" ...

  8. PCB MS SQL 存储过程(CLR) 实现Json转DataTable表的方法

    一.准备需转为DataTable的json字符串 原json字符串数据 [{"TechName":"ECN","TechNo":" ...

  9. Python数据结构同Json类型数据相互转换的用法

    在做Python接口自动化的时候,经常要用到Python数据结构同Json类型数据相互转换来供我们做进一步的验证提供数据,在此做个记录和总结 Python数据结构同Json类型数据相互转换的函数有:j ...

随机推荐

  1. 高斯过程(GP)

    随机过程基本概念: 随机过程是一个比随机变量更广泛的概念.在概率论中,通常研究一个或多个这样有限个数的随机变量,即使在大数定律和中心极限定理中考虑了无穷多个随机变量,但也要假设随机变量之间互相独立.而 ...

  2. Matlab mser(最大极值稳定区域)

    在Matlab R2013a 和R2014a中已经实现MSER特征的提取. 一.函数detectMSERFeatures 输入的是M*N的灰度图片.可以指定阈值刻度,区域范围,感兴趣区域等参数. 输出 ...

  3. [转载]Spring中MultipartHttpServletRequest实现文件上传

    实现图片上传  用户必须能够上传图片,因此需要文件上传的功能.比较常见的文件上传组件有Commons FileUpload(http://jakarta.apache.org/commons/file ...

  4. spring下配置shiro

    1.web.xml中加入shiro的过滤器: <!-- Spring --> <!-- 配置Spring配置文件路径 --> <context-param> < ...

  5. four application:geocoder widget

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  6. Android开发BUG及解决方法

    错误描述 问题1: 按照提示打开gradle-wrapper.properties文件 并且将gradle-2.8-all.zip改为gradle-2.10-all.zip,重新导入项目 问题2: 却 ...

  7. 配置NFS作为HDFS高可用的共享存储系统

    所有命令或步骤: 首先,在各个节点上安装nfs服务 yum install -y nfs service rpcbind start service nfs start 配置开机自启动服务 chkco ...

  8. MACHINE_START-内核板级初始化实现机制(linux3.1.0)

    转:https://blog.csdn.net/charliewangg12/article/details/41518549 在驱动开发时,我们都是以一块开发板为基础移植驱动程序.每一块开发板对应一 ...

  9. mini2440移植uboot 2014.04(七)

    上一篇博文:<mini2440移植uboot 2014.04(六)> 代码已经上传到github上: https://github.com/qiaoyuguo/u-boot-2014.04 ...

  10. .NET自带泛型委托方法Func、Action和Predicate

    Func.Action和Predicate是.NET自带的3个泛型委托方法,三个方法的区别其实并不大,要强行给混着用也是可以的,但是我们是有追求的人,把道理讲清楚总是好的. 一.Func是有返回值的方 ...