• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

C#NPOI导出数据到Excel

原作者: [db:作者] 来自: [db:来源] 收藏 邀请
  1         public void Export()
  2         {
  3             //创建工作簿对象
  4             IWorkbook workbook = new XSSFWorkbook();
  5 
  6             ExportStatistics(workbook);
  7             ExportHumidifyLog(workbook);
  8             ExportHumidifyEventLog(workbook);
  9             ExportHandlingEventLog(workbook);
 10 
 11             //创建流对象并设置存储Excel文件的路径
 12             using (FileStream url = File.OpenWrite(@"D:\增湿数据.xlsx"))
 13             {
 14                 //导出Excel文件
 15                 workbook.Write(url);
 16             };
 17         }
 18 
 19         private void ExportStatistics(IWorkbook workbook)
 20         {
 21             //创建工作表
 22             ISheet sheet = workbook.CreateSheet("增湿机与Handling统计");
 23             IRow row0 = sheet.CreateRow(0);
 24             row0.CreateCell(0).SetCellValue("统计项");
 25             row0.CreateCell(1).SetCellValue("循环数");
 26             row0.CreateCell(2).SetCellValue("实际循环时间");
 27             row0.CreateCell(3).SetCellValue("理论循环时间");
 28             row0.CreateCell(4).SetCellValue("运行时间");
 29             row0.CreateCell(5).SetCellValue("总时间");
 30             row0.CreateCell(6).SetCellValue("故障时间");
 31             for (int r = 0; r < Statistics.Count; r++)
 32             {
 33                 //创建行row
 34                 IRow row = sheet.CreateRow(r + 1);
 35                 row.CreateCell(0).SetCellValue(Statistics[r].SourceName);
 36                 row.CreateCell(1).SetCellValue(Statistics[r].CycleCount);
 37                 row.CreateCell(2).SetCellValue(Statistics[r].ActualCycleTime);
 38                 row.CreateCell(3).SetCellValue(Statistics[r].TheoreticalCycleTime);
 39                 row.CreateCell(4).SetCellValue(Statistics[r].UseTime);
 40                 row.CreateCell(5).SetCellValue(Statistics[r].UpTime);
 41                 row.CreateCell(6).SetCellValue(Statistics[r].DownTime);
 42             }
 43         }
 44         private void ExportHumidifyLog(IWorkbook workbook)
 45         {
 46             //创建工作表
 47             ISheet sheet = workbook.CreateSheet("增湿记录");
 48             IRow row0 = sheet.CreateRow(0);
 49             row0.CreateCell(0).SetCellValue("增湿穴");
 50             row0.CreateCell(1).SetCellValue("程序号");
 51             row0.CreateCell(2).SetCellValue("物料名称");
 52             row0.CreateCell(3).SetCellValue("增湿开始时间");
 53             row0.CreateCell(4).SetCellValue("增湿结束时间");
 54             for (int r = 0; r < HumidifyLog.Count; r++)
 55             {
 56                 //创建行row
 57                 IRow row = sheet.CreateRow(r + 1);
 58                 row.CreateCell(0).SetCellValue(HumidifyLog[r].ChamberID);
 59                 row.CreateCell(1).SetCellValue(HumidifyLog[r].HumidifyProgramNo);
 60                 row.CreateCell(2).SetCellValue(HumidifyLog[r].MaterialName);
 61                 row.CreateCell(3).SetCellValue(HumidifyLog[r].HumidifyStartTime);
 62                 row.CreateCell(4).SetCellValue(HumidifyLog[r].HumidifyEndTime);
 63             }
 64         }
 65         private void ExportHumidifyEventLog(IWorkbook workbook)
 66         {
 67             //创建工作表
 68             ISheet sheet = workbook.CreateSheet("增湿机故障统计");
 69             IRow row0 = sheet.CreateRow(0);
 70             row0.CreateCell(0).SetCellValue("故障ID");
 71             row0.CreateCell(1).SetCellValue("故障描述");
 72             row0.CreateCell(2).SetCellValue("故障开始时间");
 73             row0.CreateCell(3).SetCellValue("故障结束时间");
 74             for (int r = 0; r < HumidifyEventLog.Count; r++)
 75             {
 76                 //创建行row
 77                 IRow row = sheet.CreateRow(r + 1);
 78                 row.CreateCell(0).SetCellValue(HumidifyEventLog[r].Code);
 79                 row.CreateCell(1).SetCellValue(HumidifyEventLog[r].Remark);
 80                 row.CreateCell(2).SetCellValue(HumidifyEventLog[r].StartTime);
 81                 row.CreateCell(3).SetCellValue(HumidifyEventLog[r].EndTime);
 82             }
 83         }
 84         private void ExportHandlingEventLog(IWorkbook workbook)
 85         {
 86             //创建工作表
 87             ISheet sheet = workbook.CreateSheet("Handling故障统计");
 88             IRow row0 = sheet.CreateRow(0);
 89             row0.CreateCell(0).SetCellValue("故障ID");
 90             row0.CreateCell(1).SetCellValue("故障描述");
 91             row0.CreateCell(2).SetCellValue("故障开始时间");
 92             row0.CreateCell(3).SetCellValue("故障结束时间");
 93             for (int r = 0; r < HandlingEventLog.Count; r++)
 94             {
 95                 //创建行row
 96                 IRow row = sheet.CreateRow(r + 1);
 97                 row.CreateCell(0).SetCellValue(HandlingEventLog[r].Code);
 98                 row.CreateCell(1).SetCellValue(HandlingEventLog[r].Remark);
 99                 row.CreateCell(2).SetCellValue(HandlingEventLog[r].StartTime);
100                 row.CreateCell(3).SetCellValue(HandlingEventLog[r].EndTime);
101             }
102         }

其中,Statistics,HumidifyLog,HumidifyEventLog,HandlingEventLog为自定义类的列表。

参考:https://www.cnblogs.com/jicheng/p/5961257.html

           https://www.cnblogs.com/zqyw/category/1070314.html


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
[C#]如何在WPF程序里显示/打开网页发布时间:2022-07-10
下一篇:
c#执行sql存储过程发布时间:2022-07-10
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap