Java使用Apache.POI中HSSFWorkbook导出到Excel的实现方法
作者:小辰哥哥 发布时间:2022-05-24 17:14:13
标签:Apache.POI,HSSFWorkbook,Excel
使用Apache.POI中HSSFWorkbook导出到Excel,具体内容如下所示:
1.引入Poi依赖(3.12)
依赖如下:
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.12</version>
</dependency>
2.创建实体类(User.java)
package com.kd.nm.entity.pojo;
/**
* 实体类(User)
*
* author 小辰哥哥
*/
public class User {
// 用户编号
private String userNo;
// 用户名称
private String userName;
// 年龄
private String age;
// 无参构造
public User() {
}
// 有参构造
public User(String userNo, String userName, String age) {
this.userNo = userNo;
this.userName = userName;
this.age = age;
}
// get与set方法进行封装
public String getUserNo() {
return userNo;
}
public void setUserNo(String userNo) {
this.userNo = userNo;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getAge() {
return age;
}
public void setAge(String age) {
this.age = age;
}
// 重新toString方法
@Override
public String toString() {
return "User{" +
"userNo='" + userNo + '\'' +
", userName='" + userName + '\'' +
", age='" + age + '\'' +
'}';
}
}
3.Excel相关工具类(ExcelUtil、ReflectUtil)
package com.kd.nm.util;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import org.apache.poi.hssf.usermodel.*;
/**
* Description : Excel相关工具类
*
* @author: 小辰哥哥
*
*/
public class ExcelUtil {
/**
* 生成excel表格
* @param heads 表头内容
* @param data 数据内容
* @return
*/
public static HSSFWorkbook creatExcel(Map<String, String> heads, List data) {
// 声明一个工作薄
HSSFWorkbook workbook = new HSSFWorkbook();
// 生成一个表格
HSSFSheet sheet = workbook.createSheet();
// 生成标题行样式
HSSFCellStyle headStyle = creatStyle(workbook, (short) 14);
// 生成表格内容样式
HSSFCellStyle bodyStyle = creatStyle(workbook, (short) 10);
// 标题元素
List<String> keys = new ArrayList<String>(heads.keySet());
// 像素单位
short px = 1000;
// 设置列宽
for (int columnIndex = 0; columnIndex < keys.size(); columnIndex++) {
sheet.setColumnWidth(columnIndex, 6 * px);
}
// 生成表格
for (int rowNum = 0; rowNum <= data.size(); rowNum++) {
// 创建行
HSSFRow row = sheet.createRow(rowNum);
for (int cellNum = 0; cellNum < keys.size(); cellNum++) {
// 创建列
HSSFCell cell = row.createCell(cellNum);
// 标题
if (rowNum == 0) {
cell.setCellStyle(headStyle);
cell.setCellValue(heads.get(keys.get(cellNum)));
} else { // 内容
cell.setCellStyle(bodyStyle);
// 通过反射获取
cell.setCellValue(ReflectUtil.getValue(keys.get(cellNum), data.get(rowNum - 1)));
}
}
}
return workbook;
}
/**
* 生成样式
* @param workbook
* @param size
* @return
*/
public static HSSFCellStyle creatStyle(HSSFWorkbook workbook, short size) {
HSSFCellStyle style = workbook.createCellStyle();
style.setAlignment((HSSFCellStyle.ALIGN_CENTER));
style.setVerticalAlignment((HSSFCellStyle.VERTICAL_CENTER));
HSSFFont font = workbook.createFont();
font.setFontHeightInPoints(size);
font.setFontName("微软雅黑");
style.setFont(font);
style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
style.setBorderTop(HSSFCellStyle.BORDER_THIN);
style.setBorderRight(HSSFCellStyle.BORDER_THIN);
style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
return style;
}
}
package com.kd.nm.util;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.util.ReflectionUtils;
import java.beans.PropertyDescriptor;
import java.lang.reflect.Method;
/**
* 反射工具包
*
* @author: 小辰哥哥
*/
public class ReflectUtil {
private static final Logger logger = LoggerFactory.getLogger(ReflectUtil.class);
public static String getValue(String key, Object obj) {
String value = "";
try {
// 获取当前属性
PropertyDescriptor pd = new PropertyDescriptor(key, obj.getClass());
// 获取get方法
Method getMd = pd.getReadMethod();
value = getMd.invoke(obj).toString();
} catch (Exception e) {
logger.error("获取内容失败!");
e.printStackTrace();
}
return value;
}
public static void setValue(String key, String value, Object obj) {
try {
// 获取当前属性
PropertyDescriptor pd = new PropertyDescriptor(key, obj.getClass());
// 获取set方法
Method writeMd = pd.getWriteMethod();
writeMd.invoke(obj, value);
} catch (Exception e) {
logger.error("设置内容失败!");
e.printStackTrace();
}
}
}
4.后端控制器代码
@RequestMapping(value = "/exportExcel",method = RequestMethod.GET,produces = "application/json")
public void exportExcel(HttpServletResponse httpServletResponse) throws IOException {
// 表头内容(可在前端设置,通过参数传递进来) Key是实体类的属性值,value是表头的lable
Map<String,String> head = new HashMap<>();
head.put("userNo","用户编号");
head.put("userName","用户名称");
head.put("age","年龄");
// 表格数据内容,模拟数据库查询出来的数据
List<User> data = new ArrayList<>();
data.add(new User("1","小辰哥哥","18"));
data.add(new User("2","小猪妹妹","18"));
data.add(new User("3","大猪哥哥","18"));
// 生成工作薄
HSSFWorkbook hssfWorkbook = ExcelUtil.creatExcel(head, data);
// 定义文件名
String fileName = "导出Excel表格";
httpServletResponse.setHeader("Cache-Control", "max-age=0");
httpServletResponse.setContentType("application/vnd.ms-excel");
httpServletResponse.addHeader("Content-disposition", "attachment;filename=" + new String(fileName.getBytes("gb2312"),
"ISO-8859-1") + ".xls");
OutputStream outputStream = httpServletResponse.getOutputStream();
hssfWorkbook.write(outputStream);
outputStream.flush();
outputStream.close();
}
5.访问映射地址
接口访问:
http://localhost:9090/FaultTreatment/api/standard/exportExcel
来源:https://blog.csdn.net/weixin_43630831/article/details/115375674


猜你喜欢
- 目录1.基于注释声明缓存1.1@EnableCaching1.2@Cacheable1.2.1默认key生成规则1.2.2声明自定义key
- 如下所示:import java.security.MessageDigest;import java.security.NoSuchAlg
- LinkedList与ArrayList都是List接口的具体实现类。LinkedList与ArrayList在功能上也是大体一致,但是因为
- 前言 dubbo是一款非常优秀的服务治理型RPC框架,dubbo的优秀在于,庞大的架构体
- Android动态修改ToolBar的Menu菜单效果图实现实现很简单,就是一个具有3个Action的Menu,在我们滑动到不同状态的时候,
- 这篇文章主要介绍了Java反射通过Getter方法获取对象VO的属性值过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定
- 一、简介在实际的项目开发过程中,我们经常需要将某些变量从代码里面抽离出来,放在配置文件里面,以便更加统一、灵活的管理服务配置信息。比如,数据
- 这篇文章主要介绍了Java集合使用 Iterator 删除元素,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,
- 在Java中创建一个线程有两种方法:继承Thread类和实现Runnable接口。下面通过两个例子来分析两者的区别:1)继承Thread类p
- 最常用的序列化是把某个类序列化成二进制文件.但有时我们也会把类序列化成xml文件. 假如有如下一个类 class Arwen { priva
- @RequestBody和@ResponseBody及Stringify()的作用首先,在项目的前后交互中json数据格式比较常用,普遍认为
- 当我们打开app的时候是不是会有一瞬间的白屏然后再进入主活动,虽然这并不会造成什么不好的后果,但是感觉用户体验就不是很好。像网易云音乐等等
- 本文主要从两个方面对Android Volley框架的使用方法进行讲解,具体内容如下一、网络请求1.get方式请求数据// 1 创建一个请求
- 最近看到一个考试系统,有个功能是用来监视进程的。一旦发现如Communicator.exe这样的违禁软件就立即杀死进程并上报给服务器。我稍
- Builder模式使用链式结构创建复杂对象,将过程与结果分开,创建过程中可以自行组合。使用场景一个对象,不同组合,不同顺序生成不同的结果优点
- 图的实际应用在现实生活中,有许多应用场景会包含很多点以及点点之间的连接,而这些应用场景我们都可以用即将要学习的图这种数据结构去解决。地图:我
- 一、Stream流介绍在JDK8时,JAVA新增了lambda表达式,它与 java.io 包里的 InputStream和 OutputS
- 前言前面一篇我们介绍了使用 shared_preferences实现简单的键值对存储,然而我们还会面临更为复杂的本地存储。比如资讯类 App
- 目录题目及要求:提示:原创代码:代码思路:题目及要求:给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。提示:0 <
- 创建一个maven项目导入springboot依赖,注意底 * 释部分<?xml version="1.0&quo