java使用POI将数据导出放入Excel
本文主要是将数据库取出的数据按照自定义的行列格式导出到excel中,POI则是实现我们需求所用到的技术。
- POI介绍
- 使用spring boot导入相关依赖
- 获取数据(自行处理)
- 完整代码实例:创建excel,将数据写入excel
1.POI介绍
要想使用POI对Excel进行操作,我们需要先了解一下Excel的两种版本:一种是97-2003版本扩展名是“.xls”;一种是2007版本扩展名是“.xlsx”。POI分别针对这两种版本需要导入的jar包不同,操作类也不同。
HSSF:操作的是.xls;XSSF:操作的是.xlsx。
不管哪种操作,基本思路都是一致,先要对应一个Excel文件,然后在对应文件中的某个sheet,接下来在操作某一行和这一行中的某一列。对应POI包:文件(webbook)、sheet(sheet)、行(row)和具体单元格(cell)。
详细操作请参照POI官网的Excel(HSSF/XSSF)操作
2.通过spring boot导入依赖
为了使用java操控excel,需要将相关的jar引入,对于HSSF只需要导入POI.jar,而XSSF则需要导入四个jar,具体导入见下面代码
将代码块的依赖放入工程的pom.xml文件中就可以了。
工程不是spring boot的需要手动将下面jar导入。
<!-- HSSF需要引入的 -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>RELEASE</version>
</dependency>
<!-- XSSF需要引入的 -->
<dependency>
<groupId>org.apache.xmlbeans</groupId>
<artifactId>xmlbeans</artifactId>
<version>2.6.0</version>
</dependency>
<dependency>
<groupId>dom4j</groupId>
<artifactId>dom4j</artifactId>
<version>1.6.1</version><!--$NO-MVN-MAN-VER$ -->
</dependency>
<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.9</version>
</dependency>
3完整代码实例:简单的创建excel,将数据写入excel
依赖导入成功之后,就可以开始进行excel的生成。详细步骤在代码注释中有说明。
/**
* 创建excel
* @param listresult 是需要写入excel中的数据,通过map中的k-v来将数据写入excel
* @return
*/
private XSSFWorkbook createUserListExcel(List<Map<String,Object>> listresult){
// 1.创建HSSFWorkbook,一个HSSFWorkbook对应一个Excel文件
XSSFWorkbook wb = new XSSFWorkbook();
// 2.在workbook中添加一个sheet,对应Excel文件中的sheet
XSSFSheet sheet = wb.createSheet("sheet1");
// 3.设置表头,即每个列的列名
String[] titel = {"rowName1","rowName2","rowName3","rowName4"};
// 3.1创建第一行
XSSFRow row = sheet.createRow(0);
// 此处创建一个序号列
row.createCell(0).setCellValue("序号");
// 将列名写入
for (int i = 0; i < titel.length; i++) {
// 给列写入数据,创建单元格,写入数据
row.createCell(i+1).setCellValue(titel[i]);
}
// 写入正式数据
for (int i = 0; i < listresult.size(); i++) {
// 创建行
row = sheet.createRow(i+1);
// 序号
row.createCell(0).setCellValue(i+1);
// 医院名称
row.createCell(1).setCellValue(listresult.get(i).get("rowKey1").toString());
sheet.autoSizeColumn(1, true);
// 业务类型
row.createCell(2).setCellValue(listresult.get(i).get("rowKey2").toString());
// 异常信息
row.createCell(3).setCellValue(listresult.get(i).get("rowKey3").toString());
// 数量
row.createCell(4).setCellValue(listresult.get(i).get("rowKey4").toString());
}
/**
* 上面的操作已经是生成一个完整的文件了,只需要将生成的流转换成文件即可;
* 下面的设置宽度可有可无,对整体影响不大
*/
// 设置单元格宽度
int curColWidth = 0;
for (int i = 0; i <= titel.length; i++) {
// 列自适应宽度,对于中文半角不友好,如果列内包含中文需要对包含中文的重新设置。
sheet.autoSizeColumn(i, true);
// 为每一列设置一个最小值,方便中文显示
curColWidth = sheet.getColumnWidth(i);
if(curColWidth<2500){
sheet.setColumnWidth(i, 2500);
}
// 第3列文字较多,设置较大点。
sheet.setColumnWidth(3, 8000);
}
return wb;
}
/**
* 用户列表导出
* @param userForm
*/
private String downUserList(List<Map<String,Object>> listresult){
// getTime()是一个返回当前时间的字符串,用于做文件名称
String name = getTime();
// csvFile是我的一个路径,自行设置就行
String ys = csvFile + "//" + name + ".xlsx";
// 1.生成Excel
XSSFWorkbook userListExcel = createUserListExcel(listresult);
try{
// 输出成文件
File file = new File(csvFile);
if(file.exists() || !file.isDirectory()) {
file.mkdirs();
}
// TODO 生成的wb对象传输
FileOutputStream outputStream = new FileOutputStream(new File(ys));
userListExcel.write(outputStream);
outputStream.close();
}catch(Exception e){
e.printStackTrace();
}
return name;
}
因为工作中多次用到了这个,所以简单的记录一下,如有问题,欢迎指正。
点击进入简书地址
点击进入csdn地址
java使用POI将数据导出放入Excel的更多相关文章
- Java使用POI实现数据导出excel报表
Java使用POI实现数据导出excel报表 在上篇文章中,我们简单介绍了java读取word,excel和pdf文档内容 ,但在实际开发中,我们用到最多的是把数据库中数据导出excel报表形式.不仅 ...
- 输入三个double型的数据,放入到a,b,c三个变量中去,使用条件结构与交换逻辑将这三个变量中的值从小到大排列。
import java.util.Scanner; public class C8{ public static void main(String []args){ /* 8.输入三个double型的 ...
- 使用POI实现数据导出Excel表格
package cn.sh.bzt.kwj.action; import java.io.IOException; import java.io.OutputStream; import java.t ...
- .NET采集数据,放入数据库总结
第一次做采集Json的还简单一些但是XML的简直了......... JSON //采集数据 public string GetBetRecordToRepository()//随便你返回什么 { t ...
- java使用poi将html导出word,默认打开页面视图
<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:o ...
- sql server 数据导出(入)方法总结
我们都知道日常在面对数据需求时需要导出数据,比较少量的数据导出我们一般是通过查询后另存即可,当面对数据量比较大的时候我们应该怎么处理?我搜索总结一些几个方法:1.bcp 导出.2.数据库本身自带的导入 ...
- java 将数据库中的每一条数据取出放入数组或者List中
1.如何将数据库中数据按照行(即一整条数据)取出来,存入到数组当中? public static String str = null; // 将StringBuffer转化成字符串 public st ...
- POI 百万数据导出
poi 导出主类 package test; import java.io.File; import java.io.FileOutputStream; import java.lang.reflec ...
- Java利用POI实现导入导出Excel表格示例代码
转自:https://www.jb51.net/article/95526.htm 介绍 Jakarta POI 是一套用于访问微软格式文档的Java API.Jakarta POI有很多组件组成,其 ...
随机推荐
- js-完整轮播图
js-完整轮播图 今天写一个完整的轮播图,首先它需要实现三个功能:1.鼠标放在小圆点上实现轮播.2.点击焦点按钮实现轮播.3.无缝自动轮播. 轮播图的原理: 一系列的大小相等的图片平铺,利用CSS布 ...
- 寒假小软件开发记录06--apk生成
先在strings.xml中修改了软件名称,再修改软件图标. 在Android模式下,进入Image Asset,进行图标的修改: android studio中,build->generate ...
- Python super() 函数的概念和例子
概念: super() 函数是用于调用父类(超类)的一个方法. super 是用来解决多重继承问题的,直接用类名调用父类方法在使用单继承的时候没问题,但是如果使用多继承,会涉及到查找顺序(MRO).重 ...
- VS解决-无法打开文件“opencv_ts300d.lib”问题
之前使用过opencv,但不想要时没有正确去卸载,终造成历史问题,每次新建工程编译时都会弹出错误,然后停止运行,解决方法较笨笨 成功打印
- [原创]K8 cping 3.0大型内网渗透扫描工具
[原创]K8 Cscan 大型内网渗透自定义扫描器 https://www.cnblogs.com/k8gege/p/10519321.html Cscan简介:何为自定义扫描器?其实也是插件化,但C ...
- [ncw7] 小睿睿的方案
考虑一对情侣(x,y)x<y的贡献,设in[x],out[x]为数的dfs序. 强制从x走向y方向 当in[x]<in[y]且out[y]<=out[x] 矩形{1,in[x],in ...
- chrome强制刷新,非ctrl+f5
开发时,经常有ctrl+f5无法做到真正的强制刷新,以下可以帮到你 Ctrl+Shift+Del 清除Google浏览器缓存的快捷键 Ctrl+Shift+R 重新加载当前网页而不使用缓存内容
- Elasticsearch实践(一):基础入门
本文以 Elasticsearch 6.2.4为例. 注:最新(截止到2018-09-23)的 Elasticsearch 是 6.4.1.5.x系列和6.x系列虽然有些区别,但基本用法是一样的. 官 ...
- 在ASP.NET Core 2.2 中创建 Web API并结合Swagger
一.创建 ASP.NET Core WebApi项目 二.添加 三. ----------------------------------------------------------- 一.创建项 ...
- 【API知识】RestTemplate的使用
前言 在某种情况下,后台服务可能需要访问另一台服务器的REST接口.以前估计不少人用的都是HttpRequest类来着,结合Paser解析JSON格式的Body.现在Spring Boot的Web S ...