Convert a DataTable to Generic List Collection
Step 1: Since we need to create a List<T>, define an instance and in this list we need to add our custom type T.
Step 2: For each row we need to add the custom type T to our generic list so for each row of the DataTable I am doing that and for fetching the custom type, I used a separate function GetItem<T>.
Step 3: In the GetType<T> function I am using reflection to fetch the properties of the custom type passed and am comparing the same with column names present in the DataTable since these columns will act as properties of each type.
Step 2: For each row we need to add the custom type T to our generic list so for each row of the DataTable I am doing that and for fetching the custom type, I used a separate function GetItem<T>.
Step 3: In the GetType<T> function I am using reflection to fetch the properties of the custom type passed and am comparing the same with column names present in the DataTable since these columns will act as properties of each type.
- private static List<T> ConvertDataTable<T>(DataTable dt)
- {
- List<T> data = newList<T>();
- foreach (DataRowrow in dt.Rows)
- {
- Titem = GetItem<T>(row);
- data.Add(item);
- }
- return data;
- }
- private static TGetItem<T>(DataRow dr)
- {
- Type temp = typeof(T);
- T obj =Activator.CreateInstance<T>();
- foreach (DataColumncolumn in dr.Table.Columns)
- {
- foreach (PropertyInfopro in temp.GetProperties())
- {
- if (pro.Name == column.ColumnName)
- pro.SetValue(obj,dr[column.ColumnName], null);
- else
- continue;
- }
- }
- return obj;
- }