码迷,mamicode.com
首页 > 其他好文 > 详细

扩展方法 DataTable的ToList<T>

时间:2016-02-06 22:22:27      阅读:268      评论:0      收藏:0      [点我收藏+]

标签:

using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Text;
using System.Reflection;

namespace Extension
{

    public static class Extension
    {
        public static IList<T> ToList<T>(this DataTable dt)
        {
            var lst = new List<T>();
            var plist = new List<System.Reflection.PropertyInfo>(typeof(T).GetProperties());
            foreach (DataRow item in dt.Rows)
            {
                T t = System.Activator.CreateInstance<T>();
                for (int i = 0; i < dt.Columns.Count; i++)
                {
                    PropertyInfo info = plist.Find(p => p.Name == dt.Columns[i].ColumnName);
                    if (info != null)
                    {
                        if (!Convert.IsDBNull(item[i]))
                        {
                            info.SetValue(t, item[i], null);
                        }
                    }
                }
lst.Add(t); } return lst; ///throw new NotImplementedException(); } } }

  

DataTable dt = DAL.DAL.gettable();

var u = dt.ToList<user>();

 http://www.cnblogs.com/jasonxuvip/archive/2012/08/03/2621674.html

扩展方法 DataTable的ToList<T>

标签:

原文地址:http://www.cnblogs.com/xiaochun126/p/5133808.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!