Java通过poi创建Excel文件并分页追加数据
以下的main函数,先生成一个excel文件,并设置sheet的名称,设置excel头;而后,以分页的方式,向文件中追加数据
maven依赖
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.12</version>
</dependency> <dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.12</version>
</dependency>
代码示例
package com.**.**.**.common.utils; import org.apache.commons.io.FileUtils;
import org.apache.poi.ss.util.CellRangeAddress;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.*; /**
* @author zyydd
* @date 2019/3/15 15:00
*/
public class ExcelUtils { private static final Logger LOGGER = LoggerFactory.getLogger(ExcelUtils.class); /**
* 以下测试方法,先生成一个excel文件,并设置sheet的名称,设置excel头
* 之后,以分页的方式,向文件中增加数据
*
* @param args
*/
public static void main(String[] args) throws IOException {
String fileAbsolutePath = "D:\\test.xlsx";
Map<String, List<DataForExcel>> dataMap = initTestDataHead();
ExcelUtils.generateExcelWithManySheets(fileAbsolutePath, dataMap);
for (int i = 0; i < 3; i++) {
List<String[]> testData = new ArrayList<>();
for (int k = 1; k < 11; k++) {
String[] oneRow = new String[6];
oneRow[0] = (i * 10 + k) + "";
oneRow[1] = "张三" + oneRow[0];
oneRow[2] = "男";
oneRow[3] = "北京市朝阳区";
oneRow[4] = "北京市大兴区";
oneRow[5] = (System.currentTimeMillis() % 10000000000L) + "";
testData.add(oneRow);
}
ExcelUtils.addExcel(fileAbsolutePath, 0, testData);
}
} private static Map<String, List<DataForExcel>> initTestDataHead() {
Map<String, List<DataForExcel>> dataMap = new HashMap<String, List<DataForExcel>>();
List<DataForExcel> dataForExcelList1 = new ArrayList<DataForExcel>();
dataForExcelList1.add(new DataForExcel(0, 0, "序号"));
dataForExcelList1.add(new DataForExcel(0, 1, "姓名"));
dataForExcelList1.add(new DataForExcel(0, 2, "性别"));
dataForExcelList1.add(new DataForExcel(0, 3, "家庭住址"));
dataForExcelList1.add(new DataForExcel(0, 4, "通信地址"));
dataForExcelList1.add(new DataForExcel(0, 5, "手机号"));
dataMap.put("人员明细", dataForExcelList1);
return dataMap;
} /**
* 传入数据,在指定路径下生成Excel文件 支持生成多个sheet,并为sheet命名
*
* @param absolutePath 生成文件的绝对路径,例如"C:\\Users\\...\\out.xlsx"
* @param dataForExcelMap key:sheet名; value:传入的数据 名字相同时会覆盖之前的文件
* @return
*/
public static boolean generateExcelWithManySheets(String absolutePath, Map<String, List<DataForExcel>> dataForExcelMap) {
boolean flag = false;
try {
XSSFWorkbook workbook = new XSSFWorkbook();
for (Map.Entry<String, List<DataForExcel>> entry : dataForExcelMap.entrySet()) {
XSSFSheet sheet = workbook.createSheet(entry.getKey());
List<DataForExcel> dataForExcel = entry.getValue();
Collections.sort(dataForExcel, (arg0, arg1) -> arg0.getRow().compareTo(arg1.getRow()));
XSSFRow nrow = null;
for (DataForExcel data : dataForExcel) {
if (dataForExcel.indexOf(data) == 0 || !data.getRow().equals(dataForExcel.get(dataForExcel.indexOf(data) - 1).getRow())) {
nrow = sheet.createRow(data.getRow());
}
XSSFCell ncell = nrow.createCell(data.getColumn());
ncell.setCellValue(data.getValue());
}
}
File file = new File(absolutePath);
file.createNewFile();
FileOutputStream stream = FileUtils.openOutputStream(file);
workbook.write(stream);
stream.close();
flag = true;
} catch (IOException ie) {
LOGGER.error(ie.getMessage());
} catch (Exception e) {
LOGGER.error(e.getMessage());
}
return flag;
} /**
* 向已存在的excel中追加数据
*
* @param absolutePath 已存在的excel绝对路径
* @param sheetIndex sheet的序号,从0开始
* @param dataList cell数据
* @return
* @throws IOException
*/
public static Boolean addExcel(String absolutePath, int sheetIndex, List<String[]> dataList) throws IOException {
int columnsNum = dataList.get(0).length;
FileInputStream fs = new FileInputStream(absolutePath);
XSSFWorkbook wb = new XSSFWorkbook(fs);
XSSFSheet sheet = wb.getSheetAt(sheetIndex);
XSSFRow row;
int lastRowNum = sheet.getLastRowNum();
FileOutputStream out = new FileOutputStream(absolutePath);
for (int i = 0; i < dataList.size(); i++) {
row = sheet.createRow(++lastRowNum);
String[] addOneRowData = dataList.get(i);
for (int j = 0; j < addOneRowData.length; j++) {
String str = addOneRowData[j];
row.createCell(j).setCellValue(str);
}
}
setSheetStyle(sheet, columnsNum - 1);
wb.write(out);
out.flush();
out.close();
return true;
} private static XSSFSheet setSheetStyle(XSSFSheet sheet, int columnsNum) {
sheet.createFreezePane(0, 1, 0, 1);
String columnRange = "A1:" + (char) (65 + columnsNum) + "1";
sheet.setAutoFilter(CellRangeAddress.valueOf(columnRange));
for (int i = 0; i <= columnsNum; i++) {
sheet.autoSizeColumn(i);
}
return sheet;
} }
package com.**.**.**.common.utils; /**
* @author zyydd
* @date 2019/3/15 15:00
*/
public class DataForExcel {
/**
* excel的行号 从0开始 例如excel一个表格行号为0,列号也为0
*/
private Integer row;
/**
* excel的列号 从0开始 例如excel一个表格行号为0,列号也为0
*/
private Integer column;
/**
* 插入的值
*/
private String value; public DataForExcel() {
} public DataForExcel(Integer row, Integer column, String value) {
this.row = row;
this.column = column;
this.value = value;
} public Integer getRow() {
return row;
} public void setRow(Integer row) {
this.row = row;
} public Integer getColumn() {
return column;
} public void setColumn(Integer column) {
this.column = column;
} public String getValue() {
return value;
} public void setValue(String value) {
this.value = value;
}
}
执行截图

Java通过poi创建Excel文件并分页追加数据的更多相关文章
- Java Struts2 POI创建Excel文件并实现文件下载
Java Struts2 POI创建Excel文件并实现文件下载2013-09-04 18:53 6059人阅读 评论(1) 收藏 举报 分类: Java EE(49) Struts(6) 版权声明: ...
- java使用poi创建excel文件
import org.apache.poi.hssf.usermodel.HSSFCell;import org.apache.poi.hssf.usermodel.HSSFRow;import or ...
- java通过poi编写excel文件
public String writeExcel(List<MedicalWhiteList> MedicalWhiteList) { if(MedicalWhiteList == nul ...
- java使用POI实现excel文件的读取,兼容后缀名xls和xlsx
需要用的jar包如下: 如果是maven管理的项目,添加依赖如下: <!-- https://mvnrepository.com/artifact/org.apache.poi/poi --&g ...
- JAVA使用POI读取EXCEL文件的简单model
一.JAVA使用POI读取EXCEL文件的简单model 1.所需要的jar commons-codec-1.10.jarcommons-logging-1.2.jarjunit-4.12.jarlo ...
- java使用POI操作excel文件,实现批量导出,和导入
一.POI的定义 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作Exc ...
- Java使用POI操作Excel文件
1.简介 Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式文件读和写的功能. 2.依赖的jar包 <!-- ex ...
- java 使用POI读写Excel文件(兼容2003、2007)
package com.jadyer.demo; import java.io.File; import java.io.FileOutputStream; import java.io.IOExce ...
- Java实现POI读取Excel文件,兼容后缀名xls和xlsx
1.引入所需的jar包: maven管理项目的话直接添加以下坐标即可: <!-- https://mvnrepository.com/artifact/org.apache.poi/poi -- ...
随机推荐
- Exif认识(二)
通过php获取exif信息后,像光圈和快门的值还需要转换下,才是我们常用看得懂的值 ApertureValue的值: 拍照时镜头的光圈. 单位是 APEX. 为了转换成普通的 F-number(F-s ...
- 洛谷 p1387最大正方形
洛谷 p1387最大正方形 题目描述 在一个n*m的只包含0和1的矩阵里找出一个不包含0的最大正方形,输出边长. 输入格式 输入文件第一行为两个整数n,m(1<=n,m<=100),接下来 ...
- VS Code如何在浏览器中打开Html文件?
1.首先打开扩展 “ 文件 → 首选项 → 按键映射扩展” 快捷键:[ Ctrl+K Ctrl+M ] 2.在出现的窗口输入“open in browser”,安装 3.打开Html文件 Alt+B: ...
- Fiddler模拟响应
1 启用规则 2 不匹配的规则通过,不勾选会导致不匹配的请求失败 3 匹配url 4 响应信息,Fiddler内置了一些响应脚步,你也可以选择一个保护响应信息的文本文件
- When does VideoToolbox' VTCompressionSession benefit from hardware acceleration?
来源:http://stackoverflow.com/questions/19256897/when-does-videotoolbox-vtcompressionsession-benefit-f ...
- nginx之旅(第一篇):nginx下载安装、nginx启动与关闭、nginx配置文件详解、nginx默认网站
一.nginx下载安装 版本nginx 1.15.5 系统环境centos7.5(本机ip192.168.199.228) 关闭selinux 和防火墙firewall 1.下载 wget http: ...
- Redis内存模型(1):内存统计及划分
1. 内存统计 查看命令:info memory 示例: 部分含义: used_memory: Redis分配器分配的内存总量(单位是字节),包括使用的虚拟内存. used_memory_rss: R ...
- 利用 FluentScheduler 启动定时器计划任务
FluentScheduler 是什么? Automated job scheduler with fluent interface. 这是作者在 Github 上的介绍,就是一个定时任务管理器.在 ...
- CAS 集群部署
业务场景 单点登录服务器如果压力过大的情况,那么可以使用集群分担压力,但是cas 默认不支持session同步. 所以可以需要做session同步,可以使用j2cache 实现session同步.另外 ...
- nginx 日志问题(\x22)
nginx 日志问题(\x22) 问题: 1.request_body中含有中文时,nginx日志会转换为十六进制. 2.nginx记录问题 POST /xxxxx HTTP/1.1|200|4266 ...