欢迎莅临 SUN WU GANG 的园子!!!

世上无难事,只畏有心人。有心之人,即立志之坚午也,志坚则不畏事之不成。

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
  470 随笔 :: 0 文章 :: 22 评论 :: 30万 阅读
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

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

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

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

实例如下所示:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
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; }
    }
}

运行效果如下:

方式二:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
/// <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;
        }

  

posted on   sunwugang  阅读(194)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
历史上的今天:
2016-08-08 android学习笔记六——Spinner
2016-08-08 android学习笔记五——AutoCompleteTextView
点击右上角即可分享
微信分享提示