DataTable To List<T> DataTable Linq学习笔记

LINQ 查询适用于实现的数据源 IEnumerable<T>接口或System.Query.IQueryable接口。 

DataTable类默认是没有实现以上接口的。

所以要在DataTable中使用LINQ查询,需要调用一下AsEnumerable方法,返回一个EnumerableRowCollection<DataRow>集合。

实例如下所示:

using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Windows.Forms;

namespace DataTableToList
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private DataTable GetTable()
        {
            int[] id = { 4, 5, 1, 3, 2, 7, 6 };
            string[] name = { "Tom", "Jack", "Jime", "Lilei", "Jimo", "Koko", "Luoyi" };
            DataTable table = new DataTable("Student");
            table.Columns.Add("ID", typeof(int));
            table.Columns.Add("Name", typeof(string));

            for (int i = 0; i < id.Length; i++)
            {
                table.Rows.Add(new object[] { id[i], name[i] });
            }

            return table;
        }
        //order by
        private void button1_Click(object sender, EventArgs e)
        {
            DataTable dt = GetTable();
            var students = dt.AsEnumerable();

            //排序
            var result = students.OrderBy(x => x.Field<int>("ID"));
            //输出
            this.listBox1.Items.Clear();
            foreach (DataRow row in result)
            {
                this.listBox1.Items.Add("order by=="+row["ID"].ToString() + "==" + row["Name"].ToString());
            }
        }
        //where
        private void btnWhere_Click(object sender, EventArgs e)
        {
            DataTable dt = GetTable();
            var students = dt.AsEnumerable();
            //排序
            var result = students.Where(x => x.Field<int>("ID") > 3);
            //输出
            this.listBox1.Items.Clear();
            foreach (DataRow row in result)
            {
                this.listBox1.Items.Add("where=="+row["ID"].ToString() + "==" + row["Name"].ToString());
            }
        }

        private void btnToList_Click(object sender, EventArgs e)
        {
            DataTable dt = GetTable();
            var students = dt.AsEnumerable();
            List<Student> list = students.Select
                (
                   x => new Student
                    {
                        ID = x.Field<int>("ID"),
                        Name = x.Field<string>("Name")
                    }
                ).ToList();

            this.listBox1.Items.Clear();
            foreach (Student item in list)
            {
                this.listBox1.Items.Add("tolist=="+item.ID + "==" + item.Name);
            }
        }

    }

    public class Student
    {
        public int ID { get; set; }
        public string Name { get; set; }
    }
}

运行效果如下:

方式二:

/// <summary>
        /// DataTable转成List
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="dt"></param>
        /// <returns></returns>
        public static List<T> DataTableToList<T>(this DataTable dt)
        {
            var list = new List<T>();
            var plist = new List<PropertyInfo>(typeof(T).GetProperties());
            foreach (DataRow item in dt.Rows)
            {
                T s = 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)
                    {
                        try
                        {
                            if (!Convert.IsDBNull(item[i]))
                            {
                                object v = null;
                                if (info.PropertyType.ToString().Contains("System.Nullable"))
                                    v = Convert.ChangeType(item[i], Nullable.GetUnderlyingType(info.PropertyType));
                                else v = Convert.ChangeType(item[i], info.PropertyType);
                                info.SetValue(s, v, null);
                            }
                        }
                        catch (Exception ex)
                        {
                            throw new Exception("字段[" + info.Name + "]转换出错," + ex.Message);
                        }
                    }
                }
                list.Add(s);
            }
            return list;
        }

  

### 部署 Stable Diffusion 的准备工作 为了成功部署 Stable Diffusion,在本地环境中需完成几个关键准备事项。确保安装了 Python 和 Git 工具,因为这些对于获取源码和管理依赖项至关重要。 #### 安装必要的软件包和支持库 建议创建一个新的虚拟环境来隔离项目的依赖关系。这可以通过 Anaconda 或者 venv 实现: ```bash conda create -n sd python=3.9 conda activate sd ``` 或者使用 `venv`: ```bash python -m venv sd-env source sd-env/bin/activate # Unix or macOS sd-env\Scripts\activate # Windows ``` ### 下载预训练模型 Stable Diffusion 要求有预先训练好的模型权重文件以便能够正常工作。可以从官方资源或者其他可信赖的地方获得这些权重文件[^2]。 ### 获取并配置项目代码 接着要做的就是把最新的 Stable Diffusion WebUI 版本拉取下来。在命令行工具里执行如下指令可以实现这一点;这里假设目标路径为桌面下的特定位置[^3]: ```bash git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui.git ~/Desktop/stable-diffusion-webui cd ~/Desktop/stable-diffusion-webui ``` ### 设置 GPU 支持 (如果适用) 当打算利用 NVIDIA 显卡加速推理速度时,则需要确认 PyTorch 及 CUDA 是否已经正确设置好。下面这段简单的测试脚本可以帮助验证这一情况[^4]: ```python import torch print(f"Torch version: {torch.__version__}") if torch.cuda.is_available(): print("CUDA is available!") else: print("No CUDA detected.") ``` 一旦上述步骤都顺利完成之后,就可以按照具体文档中的指导进一步操作,比如调整参数、启动服务端口等等。整个过程中遇到任何疑问都可以查阅相关资料或社区支持寻求帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值