Должен ли я использовать конвертер кода (Python в C ++)?

Вот метод расширения для преобразования DataTable в список объектов:

    public static class Extensions
    {
        public static List<T> ToList<T>(this DataTable table) where T : new()
        {
            IList<PropertyInfo> properties = typeof(T).GetProperties().ToList();
            List<T> result = new List<T>();

            foreach (var row in table.Rows)
            {
                var item = CreateItemFromRow<T>((DataRow)row, properties);
                result.Add(item);
            }

            return result;
        }

        private static T CreateItemFromRow<T>(DataRow row, IList<PropertyInfo> properties) where T : new()
        {
            T item = new T();
            foreach (var property in properties)
            {
                if (property.PropertyType == typeof(System.DayOfWeek))
                {
                    DayOfWeek day = (DayOfWeek)Enum.Parse(typeof(DayOfWeek), row[property.Name].ToString());
                    property.SetValue(item,day,null);
                }
                else
                {
                    if(row[property.Name] == DBNull.Value)
                        property.SetValue(item, null, null);
                    else 
                        property.SetValue(item, row[property.Name], null); 
                }
            }
            return item;
        }
    }

use:

List<Employee> lst = ds.Tables[0].ToList<Employee>();

@ itay.b КОД ОБЪЯСНЕН: Мы сначала прочитали все имена свойств из класс T, использующий отражение, затем мы перебираем все строки в datatable и создаем новый объект T, тогда мы устанавливаем свойства вновь созданного объекта с помощью отражения.

Значения свойств выбираются из соответствия строки ячейка столбца.

Имя класса PS: имя класса и имена столбцов таблицы должны быть одинаковыми

-12
задан Community 23 May 2017 в 12:07
поделиться