JavaWeb动态导出Excel可弹出下载

时间:2021-09-08 21:14:55

由于项目需求,需要将数据导出成Excel表格,并且可选择导出项,可下载。项目使用的Spring+Mybatis+SpringMVC框架,利用Apache POI导出Excel。POI具体使用请自行百度。话不多说,上代码。

ExportExcelUtil代码

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
package com.rixin.common.util;
import java.io.OutputStream;
import java.lang.reflect.Method;
import java.net.URLEncoder;
import java.util.Collection;
import java.util.Iterator;
import javax.servlet.http.HttpServletResponse;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Font;
 
/**
 * 基于POI的javaee导出Excel工具类
 *
 * @author wjmisaboy@gmail.com
 * @see POI
 */
public class ExportExcelUtil {
 /**
  *
  * @param response
  *   请求
  * @param fileName
  *   文件名 如:"学生表"
  * @param excelHeader
  *   excel表头数组,存放"姓名#name"格式字符串,"姓名"为excel标题行, "name"为对象字段名
  * @param dataList
  *   数据集合,需与表头数组中的字段名一致,并且符合javabean规范
  * @return 返回一个HSSFWorkbook
  * @throws Exception
  */
 public static <T> HSSFWorkbook export(HttpServletResponse response, String fileName, String[] excelHeader,
   Collection<T> dataList) throws Exception {
  // 设置请求
  response.setContentType("application/application/vnd.ms-excel");
  response.setHeader("Content-disposition",
    "attachment;filename=" + URLEncoder.encode(fileName + ".xls", "UTF-8"));
  // 创建一个Workbook,对应一个Excel文件
  HSSFWorkbook wb = new HSSFWorkbook();
  // 设置标题样式
  HSSFCellStyle titleStyle = wb.createCellStyle();
  // 设置单元格边框样式
  titleStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);// 上边框 细边线
  titleStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN);// 下边框 细边线
  titleStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);// 左边框 细边线
  titleStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);// 右边框 细边线
  // 设置单元格对齐方式
  titleStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 水平居中
  titleStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 垂直居中
  // 设置字体样式
  Font titleFont = wb.createFont();
  titleFont.setFontHeightInPoints((short) 15); // 字体高度
  titleFont.setFontName("黑体"); // 字体样式
  titleStyle.setFont(titleFont);
  // 在Workbook中添加一个sheet,对应Excel文件中的sheet
  HSSFSheet sheet = wb.createSheet(fileName);
  // 标题数组
  String[] titleArray = new String[excelHeader.length];
  // 字段名数组
  String[] fieldArray = new String[excelHeader.length];
  for (int i = 0; i < excelHeader.length; i++) {
   String[] tempArray = excelHeader[i].split("#");// 临时数组 分割#
   titleArray[i] = tempArray[0];
   fieldArray[i] = tempArray[1];
  }
  // 在sheet中添加标题行
  HSSFRow row = sheet.createRow((int) 0);// 行数从0开始
  HSSFCell sequenceCell = row.createCell(0);// cell列 从0开始 第一列添加序号
  sequenceCell.setCellValue("序号");
  sequenceCell.setCellStyle(titleStyle);
  sheet.autoSizeColumn(0);// 自动设置宽度
  // 为标题行赋值
  for (int i = 0; i < titleArray.length; i++) {
   HSSFCell titleCell = row.createCell(i + 1);// 0号位被序号占用,所以需+1
   titleCell.setCellValue(titleArray[i]);
   titleCell.setCellStyle(titleStyle);
   sheet.autoSizeColumn(i + 1);// 0号位被序号占用,所以需+1
  }
  // 数据样式 因为标题和数据样式不同 需要分开设置 不然会覆盖
  HSSFCellStyle dataStyle = wb.createCellStyle();
  // 设置数据边框
  dataStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN);
  dataStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);
  dataStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);
  dataStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);
  // 设置居中样式
  dataStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 水平居中
  dataStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); // 垂直居中
  // 设置数据字体
  Font dataFont = wb.createFont();
  dataFont.setFontHeightInPoints((short) 12); // 字体高度
  dataFont.setFontName("宋体"); // 字体
  dataStyle.setFont(dataFont);
  // 遍历集合数据,产生数据行
  Iterator<T> it = dataList.iterator();
  int index = 0;
  while (it.hasNext()) {
   index++;// 0号位被占用 所以+1
   row = sheet.createRow(index);
   // 为序号赋值
   HSSFCell sequenceCellValue = row.createCell(0);// 序号值永远是第0列
   sequenceCellValue.setCellValue(index);
   sequenceCellValue.setCellStyle(dataStyle);
   sheet.autoSizeColumn(0);
   T t = (T) it.next();
   // 利用反射,根据传过来的字段名数组,动态调用对应的getXxx()方法得到属性值
   for (int i = 0; i < fieldArray.length; i++) {
    HSSFCell dataCell = row.createCell(i + 1);
    dataCell.setCellStyle(dataStyle);
    sheet.autoSizeColumn(i + 1);
    String fieldName = fieldArray[i];
    String getMethodName = "get" + fieldName.substring(0, 1).toUpperCase() + fieldName.substring(1);// 取得对应getXxx()方法
    Class<? extends Object> tCls = t.getClass();// 泛型为Object以及所有Object的子类
    Method getMethod = tCls.getMethod(getMethodName, new Class[] {});// 通过方法名得到对应的方法
    Object value = getMethod.invoke(t, new Object[] {});// 动态调用方,得到属性值
    if (value != null) {
     dataCell.setCellValue(value.toString());// 为当前列赋值
    }
   }
  }
 
  OutputStream outputStream = response.getOutputStream();// 打开流
  wb.write(outputStream);// HSSFWorkbook写入流
  wb.close();// HSSFWorkbook关闭
  outputStream.flush();// 刷新流
  outputStream.close();// 关闭流
  return wb;
 }
 // XSSFCellStyle.ALIGN_CENTER 居中对齐
 // XSSFCellStyle.ALIGN_LEFT 左对齐
 // XSSFCellStyle.ALIGN_RIGHT 右对齐
 // XSSFCellStyle.VERTICAL_TOP 上对齐
 // XSSFCellStyle.VERTICAL_CENTER 中对齐
 // XSSFCellStyle.VERTICAL_BOTTOM 下对齐
 
 // CellStyle.BORDER_DOUBLE 双边线
 // CellStyle.BORDER_THIN 细边线
 // CellStyle.BORDER_MEDIUM 中等边线
 // CellStyle.BORDER_DASHED 虚线边线
 // CellStyle.BORDER_HAIR 小圆点虚线边线
 // CellStyle.BORDER_THICK 粗边线
}

controller代码

?
1
2
3
4
5
6
7
8
9
10
@RequestMapping("/exportProject.do")
 public void exportProject(HttpServletResponse response, String export) {
  String[] excelHeader = export.split(",");
  List<Project> projectList = projectService.getProjects(null);
  try {
   ExportExcelUtil.export(response, "项目表", excelHeader, projectList);
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

JSP部分代码

?
1
2
3
4
5
6
7
...
<div style="margin-top: 5px;" class="am-input-group am-u-sm-4">
     <span class="am-input-group-label"><input type="checkbox"
      value="项目名称#name" name="export" checked="checked"></span> <input
      type="text" value="项目名称" disabled="disabled">
</div>
...

下面上图

JavaWeb动态导出Excel可弹出下载

JavaWeb动态导出Excel可弹出下载

以上就是本文的全部内容,希望对大家的学习有所帮助。