C\#DataTable 을 List 로 변환 합 니 다.
2392 단어 C#DataTable 에서 List<T>로 전환
생각:
List
전체 코드:
획득 한 속성 정보 반사
DataTable 의 열 정 보 는 위의 그림 과 비교 하면 속성 중의 이니셜 은 모두 대문자 이 고 열 이름 은 Camel 이름 이 며 이니셜 은 소문 자 이지 만 한 단계 디 버 깅 을 통 해 dt.Columns.Contanis(tempName)의 반환 값 이 true 라 는 것 을 알 수 있 습 니 다.이 를 통 해 비교 할 때 대소 문 자 를 구분 하지 않 는 다 는 것 을 증명 할 수 있 습 니 다.
T 개체 정보 가 져 오기
/// <summary>
/// DataTable List<T>
/// </summary>
/// <param name="dt">DataTable </param>
/// <returns>List<T> </returns>
public static List<T> DataTableToList<T>(DataTable dt) where T :class,new ()
{
//
List<T> ts = new List<T>();
//
string tempName = string.Empty;
// DataTable
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))
{
//
object value = dr[tempName];
// ,
if (value != DBNull.Value)
{
pi.SetValue(t,value,null);
}
}
}
//
ts.Add(t);
}
return ts;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 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에 따라 라이센스가 부여됩니다.