NPOI 多个Excel合并为一个Excel

实现代码

Nuget 中搜索并安装NPOI

添加引用using NPOI.HSSF.UserModel;

            var fullWork = new HSSFWorkbook();//最终的合并excel
            string exportReports = hidExportReports.Value;//需要合并的Excel文件路径
            if (!string.IsNullOrEmpty(exportReports))
            {
                var reportArrary = exportReports.Split(',');
                try
                {                   
                    for (int i = 0; i < reportArrary.Length; i++)
                    {
                        string sheetName = Path.GetFileNameWithoutExtension(reportArrary[i]).Split('_')[1];//获取sheet名称
                        var excelStream = new FileStream(reportArrary[i], FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
                        var workbook = new HSSFWorkbook(excelStream);//读取excel文件
                        HSSFSheet sheet = workbook.GetSheetAt(0) as HSSFSheet;  //获取第一个工作表(sheet)
                        sheet.CopyTo(fullWork, sheetName, true, true);//将报表合并至综合报表中
                    }
                    var stream = new MemoryStream();
                    fullWork.Write(stream);
                    byte[] bytes = stream.ToArray();
                    // Now that you have all the bytes representing the PDF report, buffer it and send it to the client.
                    Response.Buffer = true;
                    Response.Clear();
                    Response.ContentType = "application/vnd.ms-excel";
                    String filename = HttpUtility.UrlEncode("综合报表", Encoding.UTF8);
                    Response.AddHeader("content-disposition", "attachment; filename=" + filename + ".xls");
                    Response.BinaryWrite(bytes); // create the file
                    Response.Flush(); // send it to the client to download                   
                }
                catch
                {

                }
                finally
                {
                    //删除excel文件
                    for (int i = 0; i < reportArrary.Length; i++)
                    {
                        File.Delete(reportArrary[i]);
                    }
                }
            }

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要读取合并单元格的数据,需要使用 NPOI 库中的 CellRangeAddress 类来获取合并单元格的范围,并在处理每个单元格时判断它是否在合并单元格范围内。以下是一个简单的示例代码: ```csharp using NPOI.SS.UserModel; using NPOI.XSSF.UserModel; // 打开 Excel 文件 using (FileStream fs = new FileStream("test.xlsx", FileMode.Open, FileAccess.Read)) { XSSFWorkbook workbook = new XSSFWorkbook(fs); ISheet sheet = workbook.GetSheetAt(0); // 遍历所有行 for (int i = 0; i <= sheet.LastRowNum; i++) { IRow row = sheet.GetRow(i); if (row == null) continue; // 遍历所有列 for (int j = 0; j < row.LastCellNum; j++) { ICell cell = row.GetCell(j); if (cell == null) continue; // 判断单元格是否在合并单元格范围内 bool isMerged = false; for (int k = 0; k < sheet.NumMergedRegions; k++) { CellRangeAddress range = sheet.GetMergedRegion(k); if (range.IsInRange(i, j)) { isMerged = true; break; } } // 如果单元格在合并单元格范围内,则获取合并单元格的值 if (isMerged) { ICell firstCell = sheet.GetRow(range.FirstRow).GetCell(range.FirstColumn); Console.WriteLine(firstCell.ToString()); } else { Console.WriteLine(cell.ToString()); } } } } ``` 需要注意的是,由于合并单元格可能会跨越多行或多列,因此在判断单元格是否在合并单元格范围内时需要使用 CellRangeAddress 类的 IsInRange 方法。此外,如果单元格在合并单元格范围内,则需要获取合并单元格的第一个单元格的值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值