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; } |
博客内容主要用于日常学习记录,内容比较随意,如有问题,还需谅解!!!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 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