http://www.sufeinet.com/plugin.php?id=keke_group

苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 6026|回复: 3

[学生提问] 动态强制类型转换

[复制链接]
发表于 2014-12-28 21:41:46 | 显示全部楼层 |阅读模式
1金钱
说下需求    dataset转换成list<T>    datatable里的类型和list<T>不一定完全匹配  这时候可能会出错 怎么动态的吧datatable的数据类型强制类型转换成list<T>的



1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
发表于 2014-12-28 22:37:54 | 显示全部楼层
使用 dynamic类型  List<dynamic> 运行时再处理。
回复

使用道具 举报

发表于 2014-12-29 08:48:40 | 显示全部楼层
这个直接使用循环吧,根据不同情况进行判断
回复

使用道具 举报

发表于 2014-12-29 10:04:33 | 显示全部楼层
本帖最后由 ching126 于 2014-12-29 10:05 编辑

[C#] 纯文本查看 复制代码
public class Users
{ 
        //对应数据库表:Users
        //字段:ID、userName
    public int ID { get; set; }
    public string UserName { get; set; }


    private static List<T> TableToEntity<T>(DataTable dt) where T : class,new()
        {
            Type type = typeof(T);
            List<T> list = new List<T>();
         
            foreach (DataRow row in dt.Rows)
            {
                PropertyInfo[] propertyArray = type.GetProperties();
                T entity = new T();
                foreach (PropertyInfo pi in propertyArray)
                {
                    if (row[pi.UserName] is Int64)
                    {
                        pi.SetValue(entity, Convert.ToInt32(row[pi.UserName]), null);
                        continue;
                    }
                    pi.SetValue(entity, row[pi.UserName], null);
                }
                list.Add(entity);
            }
            return list;
        }

        //调用
        //DataTable dt = new DataTable();
        //List<User> userList = TableToEntity<User>(dt);
}
这是实例代码具体按照自己的情况自己写代码

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2024-11-22 08:24

© 2014-2021

快速回复 返回顶部 返回列表