c# datagridview添加list内容

using System;

using System.Collections.Generic;

using System.Data;

// 定义数据模型类

public class Person

{

public int Id { get; set; }

public string Name { get; set; }

public int Age { get; set; }

public DateTime BirthDate { get; set; }

public decimal Salary { get; set; }

public bool IsActive { get; set; }

}

class Program

{

static void Main()

{

// 1. 创建测试数据 List

List<Person> peopleList = new List<Person>

{

new Person { Id = 1, Name = "张三", Age = 30, BirthDate = new DateTime(1993, 5, 15), Salary = 5000.50m, IsActive = true },

new Person { Id = 2, Name = "李四", Age = 25, BirthDate = new DateTime(1998, 8, 20), Salary = 4500.75m, IsActive = true },

new Person { Id = 3, Name = "王五", Age = 35, BirthDate = new DateTime(1988, 3, 10), Salary = 6000.00m, IsActive = false }

};

// 2. 将 List 转换为 DataTable

DataTable peopleTable = ConvertListToDataTable(peopleList);

// 3. 显示结果

DisplayDataTable(peopleTable);

}

/// <summary>

/// 使用手动映射将 List<Person> 转换为 DataTable

/// </summary>

public static DataTable ConvertListToDataTable(List<Person> peopleList)

{

// 创建 DataTable

DataTable dataTable = new DataTable("People");

// 手动创建列(定义表结构)

dataTable.Columns.Add("ID", typeof(int));

dataTable.Columns.Add("姓名", typeof(string));

dataTable.Columns.Add("年龄", typeof(int));

dataTable.Columns.Add("生日", typeof(DateTime));

dataTable.Columns.Add("薪资", typeof(decimal));

dataTable.Columns.Add("是否激活", typeof(bool));

// 如果传入的列表为空或null,返回空表

if (peopleList == null || peopleList.Count == 0)

return dataTable;

// 手动映射每一行数据

foreach (Person person in peopleList)

{

// 创建新行

DataRow row = dataTable.NewRow();

// 手动映射每个属性到对应的列

row["ID"] = person.Id;

row["姓名"] = person.Name;

row["年龄"] = person.Age;

row["生日"] = person.BirthDate;

row["薪资"] = person.Salary;

row["是否激活"] = person.IsActive;

// 将行添加到表中

dataTable.Rows.Add(row);

}

return dataTable;

}

/// <summary>

/// 显示 DataTable 的内容(用于验证)

/// </summary>

public static void DisplayDataTable(DataTable dataTable)

{

Console.WriteLine("DataTable 内容:");

Console.WriteLine("=========================================");

// 显示列头

foreach (DataColumn column in dataTable.Columns)

{

Console.Write($"{column.ColumnName,-10} ");

}

Console.WriteLine();

Console.WriteLine(new string('-', 70));

// 显示数据行

foreach (DataRow row in dataTable.Rows)

{

Console.WriteLine($"{row["ID"],-10} {row["姓名"],-10} {row["年龄"],-10} {((DateTime)row["生日"]).ToString("yyyy-MM-dd"),-12} {row["薪资"],-10} {row["是否激活"],-10}");

}

}

}

相关推荐
我是唐青枫1 小时前
C#.NET Consul + Steeltoe 深入解析:服务注册发现、健康检查与微服务接入
c#·.net·consul
青柠代码录1 小时前
【MySQL】函数:MySQL 信息函数
程序人生
波波0071 小时前
用微软AutoGen+ 通义千问实现 AI 成语接龙
人工智能·microsoft·c#
lpfasd1239 小时前
从零开发MCP Server:原理、用法与手写实战全解析
程序人生·mcp
csdn_aspnet12 小时前
C# 求n边凸多边形的对角线数量(Find number of diagonals in n sided convex polygon)
开发语言·算法·c#
武藤一雄16 小时前
C# 设计模式大全(第一弹|7种)
microsoft·设计模式·微软·c#·.net·.netcore
格林威17 小时前
Baumer相机锂电池极片裁切毛刺检测:防止内部短路的 5 个核心方法,附 OpenCV+Halcon 实战代码!
开发语言·人工智能·数码相机·opencv·计算机视觉·c#·视觉检测
向上的车轮18 小时前
熟悉C#如何转TypeScript——SDK与包引用
开发语言·typescript·c#
CSharp精选营19 小时前
Dispose 不释放?C# 资源泄漏的 3 种隐蔽场景排查
c#·资源泄漏
unicrom_深圳市由你创科技21 小时前
LabVIEW和C#在工业控制中的应用差异是什么?
fpga开发·c#·labview