华域联盟 Linux Java使用Apache.POI中HSSFWorkbook导出到Excel的实现方法

Java使用Apache.POI中HSSFWorkbook导出到Excel的实现方法

Java使用Apache.POI中HSSFWorkbook导出到Excel的实现方法

 更新时间:2021年04月02日 10:49:26   作者:小辰哥哥  
这篇文章主要介绍了Java使用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.访问映射地址

接口访问:

localhost:9090/FaultTreatment/api/standard/exportExcel

在这里插入图片描述
在这里插入图片描述

到此这篇关于Java使用Apache.POI中HSSFWorkbook导出到Excel的实现方法的文章就介绍到这了,更多相关Apache.POI中HSSFWorkbook导出到Excel内容请搜索华域联盟以前的文章或继续浏览下面的相关文章希望大家以后多多支持华域联盟!

相关文章

  • CentOS7按时间段截取指定的Tomcat日志到指定文件的方法

    CentOS7按时间段截取指定的Tomcat日志到指定文件的方法

    这篇文章主要介绍了CentOS7按时间段截取指定的Tomcat日志到指定文件的方法的,非常不错具有参考借鉴价值,需要的朋友可以参考下

    2016-11-11

  • Lamp环境下设置绑定apache域名的方法分析

    Lamp环境下设置绑定apache域名的方法分析

    这篇文章主要介绍了Lamp环境下设置绑定apache域名的方法,简单分析了Lamp环境下的Apache域名绑定设置相关属性、功能与操作技巧,需要的朋友可以参考下

    2018-03-03

  • 利用logsave如何将命令输出保存起来

    利用logsave如何将命令输出保存起来

    logsave命令运行给定的命令,并将命令的输出信息保存到指定的日志文件中。下面这篇文章主要给大家介绍了关于利用logsave如何将命令输出保存起来的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下

    2018-05-05

  • Linux删除系统自带版本Python过程详解

    Linux删除系统自带版本Python过程详解

    这篇文章主要介绍了Linux删除系统自带版本Python过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

    2020-05-05

  • Linux文本处理命令sort详解

    Linux文本处理命令sort详解

    今天小编就为大家分享一篇关于Linux文本处理命令sort详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

    2019-03-03

  • 利用Linux防火墙隔离本地欺骗地址的方法详解

    利用Linux防火墙隔离本地欺骗地址的方法详解

    防火墙,其实说白了讲,就是用于实现Linux下访问控制的功能的,它分为硬件的或者软件的防火墙两种。下面这篇文章主要给大家介绍了关于如何利用Linux防火墙隔离本地欺骗地址的相关资料,文中介绍的非常详细,需要的朋友可以参考下

    2018-05-05

  • Linux VPS利用SSH重置ROOT密码的方法

    Linux VPS利用SSH重置ROOT密码的方法

    如果我们的VPS使用的是SolusVM客户端管理面板,我们直接在VPS商的管理后台就可以重置ROOT密码

    2012-09-09

  • 详解Linux驱动中,probe函数何时被调用

    详解Linux驱动中,probe函数何时被调用

    这篇文章主要介绍了详解Linux驱动中,probe函数何时被调用 ,具有一定的参考价值,有兴趣的同学可以了解一下。

    2016-12-12

  • linux上TCP connection timeout问题解决办法

    linux上TCP connection timeout问题解决办法

    这篇文章主要介绍了 linux上TCP connection timeout问题解决办法的相关资料,需要的朋友可以参考下

    2017-04-04

  • 详解Centos7扩展磁盘空间(LVM管理)

    详解Centos7扩展磁盘空间(LVM管理)

    本篇文章主要介绍了详解Centos7扩展磁盘空间(LVM管理),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

    2018-03-03

最新评论

本文由 华域联盟 原创撰写:华域联盟 » Java使用Apache.POI中HSSFWorkbook导出到Excel的实现方法

转载请保留出处和原文链接:https://www.cnhackhy.com/3382.htm

本文来自网络,不代表华域联盟立场,转载请注明出处。

作者: sterben

上一篇
Java使用Apache.POI中HSSFWorkbook导出到Excel的实现方法

已经没有了

Linux实现驱动模块传参过程解析

发表回复

联系我们

联系我们

2551209778

在线咨询: QQ交谈

邮箱: [email protected]

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们