欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程语言 > java >内容正文

java

Java poi插件导出Excel文件合并多sheet页

发布时间:2025/1/21 java 56 豆豆
生活随笔 收集整理的这篇文章主要介绍了 Java poi插件导出Excel文件合并多sheet页 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

文章目录

    • 一、java导出excel格式文件
    • 二、excel文件多sheet页合并

前言:2020年第一篇文章,就写这两天工作中遇到的这个小需求吧,导出多excel,每个excel有多个sheet页,需要把相同格式的excel的sheet页合并。2020年写出更优质的文章,让大家都能从中学到更多的知识。

一、java导出excel格式文件

java导出excel文件,有一个比较好的开源框架,比较好用,而且使用也非常简单,我们不必重复造轮子。

GitHub地址为:Excel4J

使用的时候可以直接引用pom文件

<dependency><groupId>com.github.crab2died</groupId><artifactId>Excel4J</artifactId><version>3.0.0-Alpha</version> </dependency>

举个简单例子:把要导出的对象组装成list,直接一行代码就可以搞定

ExcelUtils.getInstance().exportObjects2Excel(list2, header, "D:/D.xlsx");

更多具体例子可以参考:GitHub地址为:Excel4J 上面例子。

二、excel文件多sheet页合并

有时候我们会遇到类似这样的需求,比如excel文件多sheet页合并,当遇到这样的需求的时候,首先我们poi的API必需要熟悉。例如:如何创建sheet,如何创建sheet页里面的行,如何给sheet页里面的单元格赋值。

  • 创建工作簿
Workbook megreWorkbook = new XSSFWorkbook(); (2007版excel)
  • 获取工作表中的sheet页
Sheet sheetAt = book.getSheetAt(i);
  • 创建新的sheet
Sheet sheet = megreWorkbook.createSheet(workbook.getSheetName(i));
  • 创建sheet页里面的行
Row megreRow = sheet.createRow(k);
  • 给sheet页里面的单元格赋值
Cell cell = row.getCell(h);megreRow.createCell(h).setCellValue(getCellValue(cell));

主要核心代码如下

public static void megreSheet() throws Exception {Workbook megreWorkbook = null;try {megreWorkbook = new XSSFWorkbook();int k = 0;//循环读取每个excel文件List<Workbook> list = new ArrayList<>();InputStream inputStream = new FileInputStream(new File("D:\\aplus\\shuqian\\megre\\额度明细报表.xlsx"));Workbook workbook = new XSSFWorkbook(inputStream);list.add(workbook);InputStream inputStream1 = new FileInputStream(new File("D:\\aplus\\shuqian\\megre\\额度明细报表1.xlsx"));Workbook workbook1 = new XSSFWorkbook(inputStream1);list.add(workbook1);int numberOfSheets = workbook.getNumberOfSheets();for (int i = 0;i < numberOfSheets; i++) {Sheet sheet = megreWorkbook.createSheet(workbook.getSheetName(i));for (Workbook book:list) {Sheet sheetAt = book.getSheetAt(i);for (int j = 0; j < sheetAt.getLastRowNum() + 1;j++) {// 只针对第一个excel文件才读取表头,其余文件将不再读取表头if (k > 0 && j ==0) {continue;}Row megreRow = sheet.createRow(k);Row row = sheetAt.getRow(j);//读取for (int h = 0;h < row.getPhysicalNumberOfCells(); h++) {Cell cell = row.getCell(h);megreRow.createCell(h).setCellValue(getCellValue(cell));}k++;}}k = 0;}OutputStream outputStream = new FileOutputStream("D:\\aplus\\shuqian\\megre\\额度明细报表Ex.xlsx");megreWorkbook.write(outputStream);}finally {if (megreWorkbook != null) {megreWorkbook.close();}}} public static String getCellValue(Cell c) {String o;switch (c.getCellTypeEnum()) {case BLANK:o = "";break;case BOOLEAN:o = String.valueOf(c.getBooleanCellValue());break;case FORMULA:o = calculationFormula(c);break;case NUMERIC:if (DateUtil.isCellDateFormatted(c)) {o = DateUtils.date2Str(c.getDateCellValue());} else {o = String.valueOf(c.getNumericCellValue());o = matchDoneBigDecimal(o);o = RegularUtils.converNumByReg(o);}break;case STRING:o = c.getStringCellValue();break;default:o = null;break;}return o;}

测试使用excel文件格式为:

以上就是关于excel文件sheet页合并主要方法,祝大家在新的一年里面心想事成。

总结

以上是生活随笔为你收集整理的Java poi插件导出Excel文件合并多sheet页的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。