文章目录

  • 一、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页相关推荐

  1. 使用POI批量导出Excel文件(SSM)

    文章目录 前言 如何使用POI批量导出Excel文件(SSM) 一.什么是POI? 模块 二.使用步骤 1.引入依赖 2.mapper层代码 包括Mapper接口.Mapper SQL代码 Mappe ...

  2. Java 使用EasyExcel导出excel文件

    Java 使用EasyExcel导出excel文件 一.引入pom依赖 二.导出实体 三. 生成excelController 四.效果 一.引入pom依赖 <dependency>< ...

  3. java如何导出et文件_Springboot使用POI实现导出Excel文件示例

    前面讲述了使用POI导出Word文件和读取Excel文件,这两个例子都相对简单,接下来要讲述的使用POI导出Excel文件要复杂得多,内容也会比较长. 创建表头信息 表头信息用于自动生成表头结构及排序 ...

  4. java导入、导出Excel文件

    一.介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统.银行系统).或者是:我们已经习惯用Excel打印.这样在我们实际 ...

  5. Java poi实现导出excel,添加数据有效性,生成模板

    如果你是使用meaven的话,配置poi3.8就可以了,如下两个配置: <!-- poi导出excel --><dependency><groupId>org.ap ...

  6. SSIS读取一个Excel文件中不同Sheet页的几种方案

    一.Sheet页固定进入同一个表中: 1.执行SQL任务:(防止重复传入) 2.数据流:     OLE DB源的任务管理器配置:     源配置:(将随便一个Sheet页的名称设置成变量)     ...

  7. easyexcel导出excel文件合并相同单元格数据

    1.引入easyexcel依赖 !-- 阿里开源easyexcel--><dependency><groupId>com.alibaba</groupId>& ...

  8. 【JAVA】easyexcel 导出excel文件带多个图片

    最终效果 pom版本 <developer> <groupId>com.alibaba</groupId><artifactId>easyexcel&l ...

  9. java导入导出excel文件

    前言:该文章使用java集成poi来操作excel文件,此处只对poi相关api进行代码编写,对于poi的理论性知识,可在学习完这篇文章后,自行百度学习.建议大家跟着文章敲一遍代码. 创建一个mave ...

最新文章

  1. 华为手机的“美国梦”
  2. 安卓应用安全指南 5.4.1 通过 HTTPS 的通信 示例代码
  3. java xmpp消息推送_基于XMPP协议(openfire服务器)的消息推送实现
  4. html li之间的间隙,求助大神 如让图片展示在li标签里面,不要间隙 谢谢
  5. Spring MVC学习总结(5)——SpringMVC项目关于安全的一些配置与实现方式
  6. 我对前端技术更新的看法以及未来发展趋势预测
  7. 诺拉公司2.6一亿元天价罚款侵权 宅男心中的入侵
  8. undefined: resolver.BuildOption
  9. 阿里云运行python_使用阿里云运行python
  10. [fsevents@^1.2.2] optional install error: Package require os(darwin) not compatible with your platfo
  11. 基于jsp、ssm网上购物商城系统(带论文)
  12. gif动态图如何制作?
  13. FOTOO-疫情下,企业如何线上组织活动,输出企业文化
  14. 【图像压缩】DCT图像无损压缩【含GUI Matlab源码 726期】
  15. 2021-2027全球及中国G Suite销售软件行业研究及十四五规划分析报告
  16. 微信小程序封装图片合成水印
  17. python中使用modbus_tk操作浮点数
  18. 攻防世界 upload1 解题思路
  19. 【STM32】HAL库 ——DAC
  20. ArangoDB——AQL编辑器

热门文章

  1. Java基础day20
  2. rust(52)-二叉最大堆BinaryHeap
  3. python3精要(43)--变量注释
  4. tensorflow随笔-队列(1)
  5. C指针原理(22)-C指针基础-att汇编-快速排序
  6. 【机器学习】推荐一个好用的开源automl工具
  7. ​【Python】Python中的经典时间序列预测模型总结
  8. 【机器学习】3万字长文,PySpark入门级学习教程,框架思维
  9. 【Python】关于jupyter几个不得不知道的tips
  10. 【机器学习入门】机器学习基础核心算法:贝叶斯分类!(附西瓜书案例及代码实现)...