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 -- ...
 
随机推荐
- WPF 精修篇 静态资源
			
原文:WPF 精修篇 静态资源 在WPF中 如果设置好了一个控件样式或者矩形样式 如果Copy出一个新的 那么样式也会双份 比如 下面的矩形 我定义好了一个 Copy 以后 就出现一个新的 但是改变样 ...
 - C++中Matrix(矩阵)的基本运算( +、-、=、<<)
			
利用二维指针开辟空间形成二维数组: 原题为设计一个Matrix类,实现基本的矩阵运算: 初次设计为HL[10][10]数组,存放矩阵元素,后改为二维指针: 主要问题存在于二维指针理解的不透彻,无法理解 ...
 - ADO.NET 根据实体类自动生成添加修改语句仅限Oracle使用
			
话不多说直接上代码,新手上路,高手路过勿喷,请多多指教. /// <summary> /// 等于号 /// </summary> ) + Convert.ToChar() + ...
 - 英语CollaCoriiAsini阿胶CollaCoriiAsini单词
			
阿胶(colla Corii Asini)始载于<神农本草经>,是马科动物驴的皮去毛后熬制而成的胶块,其性味甘.平,具有滋阴润肺,补血.止血等功效.主要治疗血虚萎黄,眩晕心悸,肌痿无力,心 ...
 - MySQL单表最大记录数不能超过多少?
			
MySQL单表最大记录数不能超过多少? 很多人困惑这个问题.其实,MySQL本身并没有对单表最大记录数进行限制,这个数值取决于你的操作系统对单个文件的限制本身. 从性能角度来讲,MySQL单表数据不要 ...
 - maven 学习---Maven本地资源库
			
Maven的本地资源库是用来存储所有项目的依赖关系(插件jar和其他文件,这些文件被Maven下载)到本地文件夹. 很简单,当你建立一个Maven项目,所有相关文件将被存储在你的Maven本地仓库. ...
 - Android中webview html5 自动播放本地视频
			
MainActivity代码 public class Html5VideoAutoPlay extends Activity { WebView webview = null; @Override ...
 - Django框架(十)--常用字段、参数、元信息、多对多关联关系
			
一.ORM字段 # AutoField() int自增列,必须填入参数 primary_key=True.当model中如果没有自增列,则自动会创建一个列名为id的列 # IntegerField() ...
 - windows server 2012配置php环境教程
			
买了windows系统的服务器(VPS)等之后我们需要一个php环境来搭建自己的项目,这里介绍手工在windows server 2012上面配置php环境的具体步骤,适合使用服务器和VPS等的新手. ...
 - tf.Variable()、tf.get_variable()和tf.placeholder()
			
1.tf.Variable() tf.Variable(initializer,name) 功能:tf.Variable()创建变量时,name属性值允许重复,检查到相同名字的变量时,由自动别名机制创 ...