Mapper類json
using System; using System.Collections.Generic; using System.Data; using System.Globalization; using System.Linq; using System.Reflection; using System.Text; using System.Threading.Tasks; namespace CommonHelper { public class Mapper { public static object ToEntity(DataRow adaptedRow, Type entityType) { if (entityType == null || adaptedRow == null) return null; object entity = Activator.CreateInstance(entityType); CopyToEntity(entity, adaptedRow); return entity; } public static T ToEntity<T>(DataRow adaptedRow) where T : new() { T item = new T(); if (adaptedRow == null) return item; item = Activator.CreateInstance<T>(); CopyToEntity(item, adaptedRow); return item; } public static void CopyToEntity(object entity, DataRow adaptedRow) { if (entity == null || adaptedRow == null) return; PropertyInfo[] propertyInfos = entity.GetType().GetProperties(); foreach (PropertyInfo propertyInfo in propertyInfos) { if (!CanSetPropertyValue(propertyInfo, adaptedRow)) continue; try { if (adaptedRow[propertyInfo.Name] is DBNull) { propertyInfo.SetValue(entity, null, null); continue; } SetPropertyValue(entity, adaptedRow, propertyInfo); } finally { } } } public static bool CanSetPropertyValue(PropertyInfo propertyInfo, DataRow adaptedRow) { if (!propertyInfo.CanWrite) return false; if (!adaptedRow.Table.Columns.Contains(propertyInfo.Name)) return false; return true; } public static void SetPropertyValue(object entity, DataRow adaptedRow, PropertyInfo propertyInfo) { if (propertyInfo.PropertyType == typeof(DateTime?) || propertyInfo.PropertyType == typeof(DateTime)) { DateTime date = DateTime.MaxValue; DateTime.TryParse(adaptedRow[propertyInfo.Name].ToString(), CultureInfo.CurrentCulture, DateTimeStyles.None, out date); propertyInfo.SetValue(entity, date, null); } else propertyInfo.SetValue(entity, adaptedRow[propertyInfo.Name], null); } } }
DataTable拓展方法app
using Newtonsoft.Json; using System; using System.Collections.Generic; using System.Data; using System.Linq; using System.Text; using System.Threading.Tasks; namespace CommonHelper.Extensions { /// <summary> /// DataTable拓展方法 /// </summary> public static class DateTableExtensions { /// <summary> /// 將dataTable轉換爲實體類集合 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="table"></param> /// <returns></returns> public static List<T> ToCollection<T>(this DataTable table) where T : new() { if (table != null && table.Rows.Count > 0) { List<T> list = new List<T>(); foreach (DataRow dr in table.Rows) { list.Add(Mapper.ToEntity<T>(dr)); } return list; } else return new List<T>(); } /// <summary> /// 將datattable第一行轉換爲實體類 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="table"></param> /// <returns></returns> public static T FirstRowEntiy<T>(this DataTable table) where T :new() { if (table != null && table.Rows.Count > 0) return Mapper.ToEntity<T>(table.Rows[0]); else return default(T); } /// <summary> /// datatable轉2標準Jon /// </summary> /// <param name="dt">DataTable數據源</param> /// <param name="total">可選:轉普通json傳>0的值或忽略此參數;若是針對easyUI的json的必定要把total參數分頁總行數傳進來</param> /// <returns></returns> public static string ToJsonStr(this DataTable dt, int total) { System.Collections.ArrayList arrayList = new System.Collections.ArrayList(); foreach (DataRow dr in dt.Rows) { try { Dictionary<string, object> dictionary = new Dictionary<string, object>();//實例化一個參數集合 foreach (DataColumn column in dt.Columns) { dictionary.Add(column.ColumnName,dr[column.ColumnName].ToString(); } arrayList.Add(dictionary);//arrarylist中添加鍵值 } catch (Exception) { throw; } } if (total>0)//easyUI專用,分頁的總行數 { var dirctionary=new Dictionary<string,object>(); dirctionary.Add("total",total);//此參數是easyUI使用 dirctionary.Add("rows",arrayList);//此參數是easyUI使用 return JsonConvert.SerializeObject(dirctionary);//序列化參數 } else { return JsonConvert.SerializeObject(arrayList); } } } }