NOPI 导出 Excel 2007
2018-06-23 23:43:34来源:未知 阅读 ()
代码:
1 public static void ThisTo<T>( List<T> source, string[] colums, Func<T, object[]> action, string savePath, string sheetName = "") 2 { 3 XSSFWorkbook xssfworkbook = new XSSFWorkbook(); 4 ISheet sheet = xssfworkbook.CreateSheet(sheetName); 5 IRow row = sheet.CreateRow(0); 6 for (int i = 0; i < colums.Length; i++) 7 { 8 ICell cell = row.CreateCell(i); 9 cell.SetCellValue(colums[i]); 10 } 11 for (int i = 0; i < source.Count; i++) 12 { 13 IRow row1 = sheet.CreateRow(i + 1); 14 int colIndex = 0; 15 row1.Cells.AddRange(action(source[i]).Select(p => 16 { 17 var colCell = row1.CreateCell(colIndex,CellType.String); 18 colCell.SetCellValue(p.ToString()); 19 colIndex++; 20 return colCell; 21 })); 22 } 23 MemoryStream stream = new MemoryStream(); 24 xssfworkbook.Write(stream); 25 var buf = stream.ToArray(); 26 using (FileStream fs = new FileStream(savePath, FileMode.Create, FileAccess.Write)) 27 { 28 fs.Write(buf, 0, buf.Length); 29 fs.Flush(); 30 } 31 }
调用:
1 ThisTo<NAMES>(a, new string[] { "Name","Gender"}, p => 2 { 3 return new object[] { 4 p.Name, 5 p.Gender 6 }; 7 }, @"D:\ABCD.xlsx", "234");
说明:
方法中第一个参数为需导出数据,第二个参数为Excel列名,第三个为导出时数据排布顺序(与第二个参数相对应),第四参数为保存地址,第五参数为sheet名,
调用参照上述调用方法。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
下一篇:C#发送GET与POST请求
- Vue结合后台导入导出Excel问题详解 2019-08-14
- http请求post,文件导出兼容IE10+ 2019-08-14
- vue项目中导出Excel文件功能的前端代码实现 2019-08-14
- 前端JS实现一键导入excel表格 2019-08-14
- 多个浏览器下应用前端JS实现一键导出excel表 2019-08-14
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash