平時寫代碼的時候經(jīng)常會遇到DataTable與List之間的轉(zhuǎn)換操作,由于DataTable數(shù)據(jù)集合不像List指定了對應(yīng)的T類型,所以在操作的時候沒有List方便,為了方便兩個集合的轉(zhuǎn)換,特此寫下以下類記錄兩者之間的互換。
class ModelConvertHelper where T : new()
{
///
/// 把DataTable轉(zhuǎn)換成指定類型的List
///
///
///
public static IList ConvertDataTableToList(DataTable dt)
{
// 定義集合
IList ts = new List();
string tempName = "";
foreach (DataRow dr in dt.Rows)
{
T t = new T();
// 獲得此模型的公共屬性
PropertyInfo[] propertys = t.GetType().GetProperties();
foreach (PropertyInfo pi in propertys)
{
tempName = pi.Name; // 檢查DataTable是否包含此列
if (dt.Columns.Contains(tempName))
{
// 判斷此屬性是否有Setter
if (!pi.CanWrite) continue;
object value = dr[tempName];
if (value != DBNull.Value)
pi.SetValue(t, value, null);
}
}
ts.Add(t);
}
return ts;
}
///
/// 把泛型List轉(zhuǎn)換成DataTable
///
///
///
public static DataTable ConvertListToDataTable(List list)
{
DataTable dt = new DataTable();
// 獲得此模型的公共屬性
PropertyInfo[] propertys = typeof(T).GetProperties();
foreach (PropertyInfo pi in propertys)
{
// 判斷此屬性是否有Getter
if (!pi.CanRead) continue;
dt.Columns.Add(pi.Name, pi.PropertyType);
}
foreach (T item in list)
{
propertys = item.GetType().GetProperties();
DataRow newRow = dt.NewRow();
foreach (PropertyInfo pi in propertys)
{
if (!pi.CanRead) continue;
newRow[pi.Name] = pi.GetValue(item);
}
dt.Rows.Add(newRow);
}
return dt;
}
}
創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國云服務(wù)器,動態(tài)BGP最優(yōu)骨干路由自動選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡(luò)助力業(yè)務(wù)部署。公司持有工信部辦法的idc、isp許可證, 機(jī)房獨有T級流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確進(jìn)行流量調(diào)度,確保服務(wù)器高可用性。佳節(jié)活動現(xiàn)已開啟,新人活動云服務(wù)器買多久送多久。
專注于為中小企業(yè)提供成都網(wǎng)站設(shè)計、成都網(wǎng)站制作服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)安寧免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了成百上千企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。