C#DataTable(转List /JSON/字典 互转)

  1    #region  数据表DataTable 转键值对集合 List
  2         /// <summary> 
  3         /// 数据表DataTable 转键值对集合 List
  4         /// 把DataTable转成 List集合, 存每一行 
  5         /// 集合中放的是键值对字典,存每一列 
  6         /// </summary> 
  7         /// <param name="dt">数据表</param> 
  8         /// <returns>哈希表数组</returns> 
  9         public static List<Dictionary<string, object>> DataTableToList(DataTable dt)
 10         {
 11             List<Dictionary<string, object>> list
 12                  = new List<Dictionary<string, object>>();
 13 
 14             foreach (DataRow dr in dt.Rows)
 15             {
 16                 Dictionary<string, object> dic = new Dictionary<string, object>();
 17                 foreach (DataColumn dc in dt.Columns)
 18                 {
 19                     dic.Add(dc.ColumnName, dr[dc.ColumnName]);
 20                 }
 21                 list.Add(dic);
 22             }
 23             return list;
 24         }
 25         #endregion
 26 
 27         #region 数据集转键值对数组字典
 28 
 29         /// <summary> 
 30         /// 数据集转键值对数组字典 
 31         /// </summary> 
 32         /// <param name="dataSet">数据集</param> 
 33         /// <returns>键值对数组字典</returns> 
 34         public static Dictionary<string, List<Dictionary<string, object>>> DataSetToDic(DataSet ds)
 35         {
 36             Dictionary<string, List<Dictionary<string, object>>> result = new Dictionary<string, List<Dictionary<string, object>>>();
 37 
 38             foreach (DataTable dt in ds.Tables)
 39                 result.Add(dt.TableName, DataTableToList(dt));
 40 
 41             return result;
 42         }
 43         #endregion
 44 
 45         #region 数据表Tables 转JSON
 46         /// <summary> 
 47         /// 数据表转Tables JSON 
 48         /// </summary> 
 49         /// <param name="dataTable">数据表</param> 
 50         /// <returns>JSON字符串</returns> 
 51         public static string DataTableToJSON(DataTable dt)
 52         {
 53             return JsonHelper.ObjectToJSON(DataTableToList(dt));
 54         }
 55         #endregion
 56 
 57         #region 将datatable转换为json
 58         /// <summary>
 59         /// 将datatable转换为json  
 60         /// </summary>
 61         /// <param name="dtb">Dt</param>
 62         /// <returns>JSON字符串</returns>
 63         public static string Dtb2Json(DataTable dtb)
 64         {
 65             //JavaScriptSerializer jss = new JavaScriptSerializer();
 66 
 67             System.Collections.ArrayList dic = new System.Collections.ArrayList();
 68 
 69             foreach (DataRow dr in dtb.Rows)
 70             {
 71                 System.Collections.Generic.Dictionary<string, object> drow = new System.Collections.Generic.Dictionary<string, object>();
 72 
 73                 foreach (DataColumn dc in dtb.Columns)
 74                 {
 75                     drow.Add(dc.ColumnName, dr[dc.ColumnName]);
 76                 }
 77 
 78                 dic.Add(drow);
 79             }
 80 
 81             return null;
 82         }
 83         #endregion
 84 
 85         #region 将Dictionary转换为数据表数据 Tables
 86         public static DataTable DictToDataTable(Dictionary<string, object> dict)
 87         {
 88             DataTable dt = new DataTable();
 89 
 90             //dt.Columns.Add("ID", typeof(Guid));
 91             //dt.Columns.Add("DID", typeof(string));
 92             //dt.Columns.Add("DEPARTMENTNUM", typeof(string));
 93             //dt.Columns.Add("DEPARTMENTNAME", typeof(string));
 94             //dt.Columns.Add("REMARKS", typeof(string));
 95 
 96             foreach (var colName in dict.Keys)
 97             {
 98                 dt.Columns.Add(colName, typeof(string));
 99             }
100             DataRow dr = dt.NewRow();
101             foreach (KeyValuePair<string, object> item in dict)
102             {
103                 dr[item.Key] = item.Value;
104             }
105             dt.Rows.Add(dr);
106             return dt;
107         }
108         #endregion
109 
110         #region 将List转换为数据表数据 Tables
111         /// <summary>
112         /// List转DataTable
113         /// </summary>
114         public static DataTable ListToDataTable<T>(List<T> list)
115         {
116             if (list == null || list.Count == 0)
117             {
118                 return new DataTable();
119             }
120 
121             //获取T下所有的属性
122             Type entityType = list[0].GetType();
123             PropertyInfo[] entityProperties = entityType.GetProperties();
124 
125             DataTable dt = new DataTable("data");
126 
127             for (int i = 0; i < entityProperties.Length; i++)
128             {
129                 dt.Columns.Add(entityProperties[i].Name);
130             }
131 
132             foreach (var item in list)
133             {
134                 if (item.GetType() != entityType)
135                 {
136                     throw new Exception("要转换集合元素类型不一致!");
137                 }
138                 //创建一个用于放所有属性值的数组
139                 object[] entityValues = new object[entityProperties.Length];
140                 for (int i = 0; i < entityProperties.Length; i++)
141                 {
142                     entityValues[i] = entityProperties[i].GetValue(item, null);
143                 }
144 
145                 dt.Rows.Add(entityValues);
146             }
147             return dt;
148         }
149         #endregion
150 
151         #region  Json 字符串 转换为 DataTable数据集合  简要版,正在使用中
152         /// <summary>
153         /// Json 字符串 转换为 DataTable数据集合  简要版,正在使用中
154         /// </summary>
155         /// <param name="json"></param>
156         /// <returns></returns>
157         /// 
158         //格式;
159         //[{"mac":"20:f1:7c:c5:cd:80","rssi":"-86","ch":"9"},{"mac":"20:f1:7c:c5:cd:85","rssi":"-91","ch":"9"}]
160         public static DataTable ToDataTableTwo(string json)
161         {
162             DataTable dataTable = new DataTable();  //实例化
163             DataTable result;
164             try
165             {
166                 List<Dictionary<string, object>> arrayList = JsonHelper.JSONToObject<List<Dictionary<string, object>>>(json);
167 
168                 if (arrayList != null && arrayList.Count > 0)
169                 {
170                     foreach (Dictionary<string, object> dictionary in arrayList)
171                     {
172                         if (dictionary.Keys.Count == 0)
173                         {
174                             result = dataTable;
175                             return result;
176                         }
177 
178                         //Columns
179                         if (dataTable.Columns.Count == 0)
180                         {
181                             foreach (var current in dictionary)
182                             {
183                                 if (current.Value != null)
184                                 {
185                                     dataTable.Columns.Add(current.Key, current.Value.GetType());
186                                 }
187                                 else
188                                 {
189                                     dataTable.Columns.Add(current.Key);
190                                 }
191                             }
192                         }
193 
194                         //Rows
195                         DataRow dataRow = dataTable.NewRow();
196 
197                         foreach (string current in dictionary.Keys)
198                         {
199                             if (dictionary[current] != null)
200                             {
201                                 dataRow[current] = dictionary[current];
202                             }
203                         }
204 
205                         dataTable.Rows.Add(dataRow); //循环添加行到DataTable中
206                     }
207                 }
208             }
209             catch (Exception ex)
210             {
211                 throw ex;
212             }
213 
214             result = dataTable;
215             return result;
216         }
217         #endregion

 

posted @ 2021-12-03 09:30  园友2288976  阅读(1568)  评论(0编辑  收藏  举报