java POI操作execel导出

简介: 最近项目当中在使用POI将数据填充置row和cell等行和列,最后导出成execel到前端。一开始使用的方式是一个个去赋值,但是这样做有点麻烦,代码也有点长,不太好维护。

最近项目当中在使用POI将数据填充置row和cell等行和列,最后导出成execel到前端。一开始使用的方式是一个个去赋值,但是这样做有点麻烦,代码也有点长,不太好维护。于是换了种方案,先导入固定模板,然后将要添加数据的那部分动态添加过去并且进行填充,这样做的好处有利于后期的维护和可扩展,模板可以随时换。在这过程中也学到了不少POI方面的知识。下面总结一下.

  HSSFWorkbook与xssfworkbook的区别:前者只支持xls(2003)的表格,后者支持xlsx(2007)的表格

我这里主要介绍HSSFWorkbook,

以下是HSSFWorkBook常用代码

Workbook workBook=new HSSFWorkbook();//工作簿        定义一个新工作簿
Sheet sheet = workBook.createSheet("第一个sheet页"); //工作表       表创建一个sheet工作表  
Row row = sheet.createRow(0); //行       下标从0开始,0代表创建第一行,1代表创建第二行
Cell cell = row.createCell(0); //单元格    创建一个单元格,0代表第一个,1代表第二个
Cell cell = row.createCell(1);//在第一行中创建第二个单元格,也就是第一行,第二列
cell.setCellValue(1);   //给单元格设置值,当然设置数字,string都行,8大基本数据类型设置都可以,new Data日期也可以
----------合并单元格-----------------------------------------------------------------------
  Cell cell=row.createCell(1);
        cell.setCellValue("单元格合并测试");
        sheet.addMergedRegion(new CellRangeAddress(
                1, // 起始行
                2, // 结束行
                1, // 其实列
                2  // 结束列
        ));
----------合并单元格---------------------------------------------------------------
<!-- poi execel要引入的包 -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.9</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.17</version>
</dependency>
<!-- poi execel要引入的包 -->

由于输出到execel的时候,如果一下子导出到execel当中的话,有的时候很难看清问题,可以复制一个row,然后输出一次流,再进行查看。

FileOutputStream fileOut1 = null;
try {
    fileOut1 = new FileOutputStream(saveFileName);
    workbook.write(fileOut1);
    fileOut1.close();
    fileOut1.flush();
}catch (Exception e){

}
System.out.println("查看表格");

遇到的一个坑.模板导入后写入数据一切OK,但是导出的xls文件有几十兆,打开以后直接保存一下,文件又变成几十KB,但是这个非常影响性能,经过调试发现,我的sheet1里面row复制完继续在sheet1里操作,我理解的时候可能被当做sheet间的复制了,所以我createSheet了以后,把sheet1的内容复制到新建的sheet后就没这问题了。

相关文章推荐:索引链接
自己写的POIUtil,主要解决从不同的HSSFWorkbook复制sheet以及根据单元格插入图片等
Excel动态合并行、合并列
Java Web利用POI导出Excel简单例子
POI 方式导出文件,浏览器(适用Edge浏览器)文件名乱码解决
POI使用详解
java 实现 excel sheet 拷贝到另一个Excel文件中 poi

目录
相关文章
|
3月前
|
缓存 easyexcel Java
Java EasyExcel 导出报内存溢出如何解决
大家好,我是V哥。使用EasyExcel进行大数据量导出时容易导致内存溢出,特别是在导出百万级别的数据时。以下是V哥整理的解决该问题的一些常见方法,包括分批写入、设置合适的JVM内存、减少数据对象的复杂性、关闭自动列宽设置、使用Stream导出以及选择合适的数据导出工具。此外,还介绍了使用Apache POI的SXSSFWorkbook实现百万级别数据量的导出案例,帮助大家更好地应对大数据导出的挑战。欢迎一起讨论!
287 1
|
2月前
|
Java API Apache
|
2月前
|
存储 Java API
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
81 4
|
4月前
|
存储 Java
java的Excel导出,数组与业务字典匹配并去掉最后一个逗号
java的Excel导出,数组与业务字典匹配并去掉最后一个逗号
66 2
|
3月前
|
Java Apache
Apache POI java对excel表格进行操作(读、写) 有代码!!!
文章提供了使用Apache POI库在Java中创建和读取Excel文件的详细代码示例,包括写入数据到Excel和从Excel读取数据的方法。
76 0
|
4月前
|
Java Apache Maven
Java中使用poi+poi-tl实现根据模板导出word文档
这个过程不仅简化了文档生成的工作,而且保证了生成文档的一致性与准确性,特别适合于那些需要生成大量文档的自动化场景。通过以上步骤,Java开发人员可以实现高效、可靠的Word文档导出功能。
1687 0
|
6月前
|
存储 Java 索引
Java ArrayList操作指南:如何移除并返回第一个元素
通过上述方法,你可以方便地从Java的 `ArrayList` 中移除并返回第一个元素。这种操作在日常编程中非常常见,是处理列表时的基本技能之一。希望这篇指南能帮助你更好地理解和运用Java的 `ArrayList`。
65 4
|
6月前
|
Java 数据安全/隐私保护
Java无模版导出Excel 0基础教程
经常写数据导出到EXCEL,没有模板的情况下使用POI技术。以此作为记录,以后方便使用。 2 工具类 样式工具: 处理工具Java接口 水印工具 导出Excel工具类 3 测试代码 与实际复杂业务不同 在此我们只做模拟 Controller Service 4 导出测试 使用Postman进行接口测试,没接触过Postman的小伙伴可以看我这篇博客Postman导出excel文件保存为文件可以看到导出很成功,包括水印 sheet页名称自适应宽度。还有一些高亮……等功能可以直接搜索使用
122 0
Java无模版导出Excel 0基础教程
|
6月前
|
分布式计算 DataWorks Java
DataWorks操作报错合集之使用ODPS Tunnel Upload功能时,遇到报错:Java 堆内存不足,该如何解决
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
|
6月前
|
easyexcel Java Apache
EasyExcel导入的时候报错Caused by: java.lang.NoClassDefFoundError: org/apache/poi/poifs/filesystem/File
EasyExcel导入的时候报错Caused by: java.lang.NoClassDefFoundError: org/apache/poi/poifs/filesystem/File
469 0