日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

将JSON转成DataSet(DataTable)

發(fā)布時間:2024/7/19 javascript 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 将JSON转成DataSet(DataTable) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

方法1:

/// <summary>/// 將JSON解析成DataSet只限標(biāo)準(zhǔn)的JSON數(shù)據(jù)/// 例如:Json={t1:[{name:'數(shù)據(jù)name',type:'數(shù)據(jù)type'}]} /// 或 Json={t1:[{name:'數(shù)據(jù)name',type:'數(shù)據(jù)type'}],t2:[{id:'數(shù)據(jù)id',gx:'數(shù)據(jù)gx',val:'數(shù)據(jù)val'}]}/// </summary>/// <param name="Json">Json字符串</param>/// <returns>DataSet</returns>public static DataSet JsonToDataSet(string Json){try{DataSet ds = new DataSet();JavaScriptSerializer JSS = new JavaScriptSerializer();object obj = JSS.DeserializeObject(Json);Dictionary<string, object> datajson = (Dictionary<string, object>)obj;foreach (var item in datajson){DataTable dt = new DataTable(item.Key);object[] rows = (object[])item.Value;foreach (var row in rows){Dictionary<string, object> val = (Dictionary<string, object>)row;DataRow dr = dt.NewRow();foreach (KeyValuePair<string, object> sss in val){if (!dt.Columns.Contains(sss.Key)){dt.Columns.Add(sss.Key.ToString());dr[sss.Key] = sss.Value;}elsedr[sss.Key] = sss.Value;}dt.Rows.Add(dr);}ds.Tables.Add(dt);}return ds;}catch{return null;}}

方法2:

/// <summary> /// 根據(jù)Json返回DateTable,JSON數(shù)據(jù)格式如: /// {table:[{column1:1,column2:2,column3:3},{column1:1,column2:2,column3:3}]} /// items:{"2750884":{clicknum:"50",title:"鮑魚",href:"/shop/E06B14B40110/dish/2750884#menu",desc:"<br/>",src:"15f38721-49da-48f0-a283-8057c621b472.jpg",price:78.00,units:"",list:[],joiner:""}}/// </summary> /// <param name="strJson">Json字符串</param> /// <returns></returns> public static DataTable JsonToDataTable(string strJson){//取出表名 //var rg = new Regex(@"(?<={)[^:]+(?=:\[)", RegexOptions.IgnoreCase);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("}"));//獲取數(shù)據(jù) //rg = new Regex(@"(?<={)[^}]+(?=})");rg = new Regex(@"(?<={)[^}]+(?=})");System.Text.RegularExpressions.MatchCollection mc = rg.Matches(strJson);for (int i = 0; i < mc.Count; i++){string strRow = mc[i].Value;string[] strRows = strRow.Split(',');//創(chuàng)建表 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];tb.Columns.Add(dc);}tb.AcceptChanges();}//增加內(nèi)容 DataRow dr = tb.NewRow();for (int r = 0; r < strRows.Length; r++){//dr[r] = strRows[r].Split(':')[1].Trim().Replace(",", ",").Replace(":", ":").Replace("\"", "");dr[r] = strRows[r];}tb.Rows.Add(dr);tb.AcceptChanges();}return tb;}

?

轉(zhuǎn)載于:https://www.cnblogs.com/elves/p/3604499.html

總結(jié)

以上是生活随笔為你收集整理的将JSON转成DataSet(DataTable)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。