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}]

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

时间: 2024-08-28 00:43:04

json 转换 为 DataTable的相关文章

atitit.XML类库选型及object 对象bean 跟json转换方案

atitit.XML类库选型及object 对象bean 跟json转换方案 1. XML类库可以分成2大类.标准的.这些类库通常接口和实现都是分开的 1 2. 常见的xml方面的方法 2 2.1. xml解析 2 2.2. bean与xml互相转换 2 2.3. json与xml的互相转换 2 3. 大名鼎鼎的 DOM  绿色环保的 SAX 默默无闻的 Digester 2 3.1. 默默无闻的 Digester:XML 的 JavaBean 化 2 4. Digester 解析 XML 3

比Newtonsoft.Json轻量快速简洁的实体JSON转换库YeaJur.Mapper

在使用MVC的时候,我们经常用到Newtonsoft.Json来进行实体和JSON 之间的转换,但是有时候,有些实体Newtonsoft.Json转换会出现异常.YeaJur.Mapper正是为了解决这些问题而来,并比Newtonsoft.Json轻量,转换速度快,使用简洁,测试结果如下 PK项 YeaJur.Mapper Newtonsoft.Json 版本 1.0 9.0.1 大小 6KB 514KB 实例(json格式) [ { "Products": [ { "Id&

list 转换成datatable

感谢网上的一位朋友 1 /// <summary> 2 60 /// 将集合类转换成DataTable 3 61 /// </summary> 4 62 /// <param name="list">集合</param> 5 63 /// <returns></returns> 6 64 public static DataTable ToDataTable(IList list) 7 65 { 8 66 Data

JSON转换

JSON简介 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它易于编程人员阅读和编写,同时也易于机器解析和生成.它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition – December 1999的一个子集.JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)

XML,Object,Json转换之浅析Xstream的使用

XML,Object,Json转换之浅析Xstream的使用 请尊重他人的劳动成果,转载请注明出处:XML,Object,Json转换之浅析Xstream的使用 XStream的是一个简单的库,主要用于Java对象和XML之间的转换.但XStream也内置了对Json的支持. 1.Xstream的特点: 这里直接引用Xstream官方的叙述: 灵活易用:在更高的层次上提供了简单.灵活.易用的统一接口,用户无需了解项目的底层细节 无需映射:大多数对象都可以在无需映射的情况下进行序列化与反序列化的操

将list&lt;对象&gt;转换成DataTable,把DataTable转换成参数传入存储过程实现批量插入数据

领导让在存储过程中批量添加数据,找出效率最高的,我看到后台代码后,发现可以将list<对象>转换成DataTable,把DataTable转换成参数传入存储过程实现批量插入数据,知道还有其他的方法,不过这个方法已经实现,就写一下了: 1.创建表. CREATE TABLE [dbo].[person]( [ID] [int] IDENTITY(1,1) NOT NULL, [Name] [nvarchar](50) NULL, [Pwd] [nvarchar](50) NULL, [Age]

Newtonsoft.Json 转换DateTime类型为字符串时,串内部会有一个T。解决方案

使用Newtonsoft.Json 转换DateTime类型时,若使用标准转换,则字符串内会有一个T(虽然再转换成DateTime没有问题). 若要转换成DateTime没有T,可以加上特性: 1 public class TestClass 2 { 3 public TestClass() 4 { 5 Dt1 = Dt2 = new DateTime(1900, 1, 1, 0, 0, 0); 6 } 7 8 [JsonConverter(typeof(TcDateTimeConverter)

C# DataTable转换成实体列表 与 实体列表转换成DataTable

/// <summary> /// DataTable转换成实体列表 /// </summary> /// <typeparam name="T">实体 T </typeparam> /// <param name="table">datatable</param> /// <returns></returns> public static IList<T>

.net excel 转换成datatable,创建文件夹

protected void Button9_Click(object sender, EventArgs e) { string path = ""; path = FileUpload3.PostedFile.FileName; if (path == "") { string jss = "<script language='javascript' type='text/javascript'> alert('先选择文件')</sc