• json 转换 为 DataTable


    网上有很多json和 List<T>的相互转换还有很多DataTable转换为json的代码,但是json转换为DataTable的代码却很少,最近在工作中恰好用到,百度了一下找了半天,在百度知道里面找了个能用的,但是不太好用,又稍微改造了一下,现在用着感觉还行.

           /// <summary>
    /// 将json转换为DataTable
    /// </summary>
    /// <param name="strJson">得到的json</param>
    /// <returns></returns>
    private DataTable JsonToDataTable(string strJson)
    {
    //转换json格式
    strJson = strJson.Replace(",\"", "*\"").Replace("\":", "\"#").ToString();
    //取出表名
    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('#');

    if (strCell[0].Substring(0, 1) == "\"")
    {
    int a = strCell[0].Length;
    dc.ColumnName = strCell[0].Substring(1, a - 2);
    }
    else
    {
    dc.ColumnName = strCell[0];
    }
    tb.Columns.Add(dc);
    }
    tb.AcceptChanges();
    }

    //增加内容
    DataRow dr = tb.NewRow();
    for (int r = 0; r < strRows.Length; r++)
    {
    dr[r] = strRows[r].Split('#')[1].Trim().Replace("", ",").Replace("", ":").Replace("\"", "");
    }
    tb.Rows.Add(dr);
    tb.AcceptChanges();
    }

    return tb;
    }

    另外需要注意的是,json的格式要规范一些

    [{peice:100,price:100}]

    对于这种格式未作判断,如果这样写的话便不能正确转换,要给price加上双引号

    [{"peice":100,"price":100}]

    直接使用没有什么大问题,细节上可能还会有一些小问题需要修改一下,有问题的话可以提出.

  • 相关阅读:
    net core体系-2继续认识net core
    net core体系-1概要
    iOS开发UI篇—懒加载
    iOS开发UI篇—简单的浏览器查看程序
    iOS开发UI篇—transframe属性(形变)
    iOS开发UI基础—手写控件,frame,center和bounds属性
    iOS开发UI篇—Button基础
    Foundation框架—集合
    Foundation框架—字符串
    Foundation框架—结构体
  • 原文地址:https://www.cnblogs.com/ChengDong/p/2628242.html
Copyright © 2020-2023  润新知