1 public static void ExportExcel<T>(List<T> ts,string filename) 2 { 3 var model = ts.FirstOrDefault(); 4 List<PropertyInfo> titles = model.GetType().GetProperties().ToList(); 5 using (ExcelPackage package = new ExcelPackage()) 6 { 7 // 添加一个工作表 8 ExcelWorksheet worksheet = package.Workbook.Worksheets.Add("Sheet1"); 9 // 获取第一行用于标题 10 int row = 1; 11 // 对象的第一个元素的所有键,用作Excel的列标题 12 int col = 1; 13 foreach (var title in titles) 14 { 15 worksheet.Cells[row, col].Value = title.Name; 16 col++; 17 } 18 // 填充数据行,从第二行开始 19 row = 2; 20 foreach (var item in ts) 21 { 22 col = 1; 23 List<PropertyInfo> props = item.GetType().GetProperties().ToList(); 24 foreach (var prop in props) 25 { 26 worksheet.Cells[row, col].Value = prop.GetValue(item); 27 col++; 28 } 29 row++; 30 } 31 // 保存Excel文件到磁盘 32 FileInfo excelFile = new FileInfo($"{model.GetType().Name}_{filename}_{DateTime.Now.ToString("yyyyMMddHHmmss")}.xlsx"); 33 package.SaveAs(excelFile); 34 } 35 }
引用
<PackageReference Include="EPPlus.Core" Version="1.5.4" />
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下
2016-04-23 ORACLE 监听配置