C#반사 적용
5591 단어 C#
public class DatatableListHelper<T>
{
public static DataTable GetDataTableHelper(List<T> items)
{
DataTable dt = new DataTable();
Type t = items[0].GetType();
PropertyInfo[] pis = t.GetProperties();
foreach (PropertyInfo pi in pis)
{
dt.Columns.Add(pi.Name);
}
foreach (T item in items)
{
DataRow dr = dt.NewRow();
foreach (PropertyInfo pi in pis)
{
object obj = pi.GetValue(item, null);
switch (pi.PropertyType.Name.ToString().ToLower())
{
case "datetime" :
dr[pi.Name] = Convert.ToDateTime(obj).ToString("yyyy-MM-dd");
break;
case "int32":
dr[pi.Name] = Convert.ToInt32(obj);
break;
case "double":
dr[pi.Name] = Convert.ToDouble(obj);
break;
default:
dr[pi.Name] = obj;
break;
}
}
dt.Rows.Add(dr);
}
return dt;
}
}
switch에 유형이 완전하지 않아서 유형을 추가해야 합니다
반대로 데이터테이블을 대상으로 바꾸면 반사로도 할 수 있을 거예요.
public static List<T> GetObjectListHelper(DataTable dt, T obj)
{
List<T> list = new List<T>();
Type type = obj.GetType();
PropertyInfo[] pis = type.GetProperties();
foreach (DataRow dr in dt.Rows)
{
object o = Activator.CreateInstance(type);
foreach (PropertyInfo pi in pis)
{
//pi.SetValue(o, dr[pi.Name].ToString(), null);
switch (pi.PropertyType.Name.ToString().ToLower())
{
case "datetime":
pi.SetValue(o, Convert.ToDateTime(dr[pi.Name].ToString()), null);
break;
case "int32":
pi.SetValue(o, Convert.ToInt32(dr[pi.Name].ToString()), null);
break;
case "double":
pi.SetValue(o, Convert.ToDouble(dr[pi.Name].ToString()), null);
break;
default:
pi.SetValue(o, dr[pi.Name].ToString(), null);
break;
}
}
T t = (T)o;
list.Add(t);
}
return list;
}
데이터테이블 하나만 올리고 싶었는데 T를 올리고 싶지 않았어요. 좋은 방법이 생각나지 않았어요. 좋은 조언이 있으면 지도해 주세요.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
WebView2를 Visual Studio 2017 Express에서 사용할 수 있을 때까지Evergreen .Net Framework SDK 4.8 VisualStudio2017에서 NuGet을 사용하기 때문에 패키지 관리 방법을 packages.config 대신 PackageReference를 사용해야...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.