SpringBoot實(shí)現(xiàn)excel文件生成和下載
更新時(shí)間:2021年02月09日 14:05:28 作者:shengshenglalala
這篇文章主要為大家詳細(xì)介紹了SpringBoot實(shí)現(xiàn)excel文件生成和下載,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
使用SpringBoot實(shí)現(xiàn)excel生成和下載,生成模板如下

controller
@RequestMapping(value = { "/downloadExcelTemplate" }, method = RequestMethod.GET)
public String downloadExcelTemplate(HttpSession httpSession, HttpServletResponse response) {
try {
dealExcelService.downloadExcelTemplate(response);
return "success";
} catch (Exception e) {
logger.error("downloadExcelTemplate_error", e);
return "failure";
}
}
service
public void downloadExcelTemplate(HttpServletResponse response) throws Exception {
//文件名
SimpleDateFormat format3 = new SimpleDateFormat("yyyyMMddHHmm");
String fileName = new String(("文件名" + format3.format(new Date()) + "導(dǎo)入模板").getBytes(), "ISO8859_1");
//配置請(qǐng)求頭
ServletOutputStream outputStream = response.getOutputStream();
// 組裝附件名稱和格式
response.setHeader("Content-disposition", "attachment; filename=" + fileName + ".xlsx");
// 創(chuàng)建一個(gè)workbook 對(duì)應(yīng)一個(gè)excel應(yīng)用文件
XSSFWorkbook workBook = new XSSFWorkbook();
// 在workbook中添加一個(gè)sheet,對(duì)應(yīng)Excel文件中的sheet
XSSFSheet sheet = workBook.createSheet("模板");
ExportUtil exportUtil = new ExportUtil(workBook, sheet);
XSSFCellStyle headStyle = exportUtil.getHeadStyle();
XSSFCellStyle bodyStyle = exportUtil.getBodyStyle2();
// 構(gòu)建表頭
XSSFRow headRow = ExportUtil.createRow(sheet, 0);
XSSFCell cell;
String[] titles = {"表頭一", "表頭二", "表頭三"};
int index = 0;
for (String title : titles) {
cell = ExportUtil.createCell(headRow, index);
cell.setCellStyle(headStyle);
cell.setCellValue(title);
index++;
}
try {
workBook.write(outputStream);
outputStream.flush();
outputStream.close();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
outputStream.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
ExportUtil導(dǎo)出工具類
package com.shengsheng.utils;
import org.apache.poi.hssf.util.HSSFColor;
import org.apache.poi.ss.util.CellRangeAddress;
import org.apache.poi.xssf.usermodel.*;
/**
* excel 表格導(dǎo)出工具類
*
* @author shengshenglalala
*/
public class ExportUtil {
private XSSFWorkbook wb;
private XSSFSheet sheet;
/**
* @param wb
* @param sheet
*/
public ExportUtil(XSSFWorkbook wb, XSSFSheet sheet) {
this.wb = wb;
this.sheet = sheet;
}
/**
* 合并單元格后給合并后的單元格加邊框
*
* @param region
* @param cs
*/
public void setRegionStyle(CellRangeAddress region, XSSFCellStyle cs) {
int toprowNum = region.getFirstRow();
for (int i = toprowNum; i <= region.getLastRow(); i++) {
XSSFRow row = sheet.getRow(i);
for (int j = region.getFirstColumn(); j <= region.getLastColumn(); j++) {
XSSFCell cell = row.getCell(j);
cell.setCellStyle(cs);
}
}
}
/**
* 設(shè)置表頭的單元格樣式
*
* @return
*/
public XSSFCellStyle getHeadStyle() {
// 創(chuàng)建單元格樣式
XSSFCellStyle cellStyle = wb.createCellStyle();
// // 設(shè)置單元格的背景顏色為淡藍(lán)色
cellStyle.setFillForegroundColor(HSSFColor.PALE_BLUE.index);
cellStyle.setFillPattern(XSSFCellStyle.SOLID_FOREGROUND);
// 設(shè)置單元格居中對(duì)齊
cellStyle.setAlignment(XSSFCellStyle.ALIGN_CENTER);
// 設(shè)置單元格垂直居中對(duì)齊
cellStyle.setVerticalAlignment(XSSFCellStyle.VERTICAL_CENTER);
// 創(chuàng)建單元格內(nèi)容顯示不下時(shí)自動(dòng)換行
// cellStyle.setWrapText(true);
// 設(shè)置單元格字體樣式
XSSFFont font = wb.createFont();
// 設(shè)置字體加粗
font.setBoldweight(XSSFFont.BOLDWEIGHT_BOLD);
font.setFontName("宋體");
// font.setFontHeight((short) 200);
cellStyle.setFont(font);
// 設(shè)置單元格邊框?yàn)榧?xì)線條
// cellStyle.setBorderLeft(XSSFCellStyle.BORDER_THIN);
// cellStyle.setBorderBottom(XSSFCellStyle.BORDER_THIN);
// cellStyle.setBorderRight(XSSFCellStyle.BORDER_THIN);
// cellStyle.setBorderTop(XSSFCellStyle.BORDER_THIN);
return cellStyle;
}
/**
* 設(shè)置表體的單元格樣式
*
* @return
*/
public XSSFCellStyle getBodyStyle2() {
// 創(chuàng)建單元格樣式
// 創(chuàng)建單元格樣式
XSSFCellStyle cellStyle = wb.createCellStyle();
// 創(chuàng)建單元格內(nèi)容顯示不下時(shí)自動(dòng)換行
// cellStyle.setWrapText(true);
// 設(shè)置單元格字體樣式
XSSFFont font = wb.createFont();
// 設(shè)置字體加粗
// font.setBoldweight(XSSFFont.BOLDWEIGHT_BOLD);
font.setFontName("宋體");
font.setFontHeight((short) 200);
font.setColor(HSSFColor.BLACK.index);
cellStyle.setFont(font);
// 設(shè)置單元格邊框?yàn)榧?xì)線條
return cellStyle;
}
/**
* 沒(méi)有行,就創(chuàng)建行
*
* @param sheet
* @param index
* @return
*/
public static XSSFRow createRow(XSSFSheet sheet, Integer index) {
XSSFRow row = sheet.getRow(index);
if (row == null) {
return sheet.createRow(index);
}
return row;
}
/**
* 如果沒(méi)有列,就創(chuàng)建列
*
* @param row
* @param index
* @return
*/
public static XSSFCell createCell(XSSFRow row, Integer index) {
XSSFCell cell = row.getCell(index);
if (cell == null) {
return row.createCell(index);
}
return cell;
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
tdesign的文件上傳功能實(shí)現(xiàn)(微信小程序+idea的springboot)
這篇文章主要介紹了tdesign的文件上傳(微信小程序+idea的springboot)的相關(guān)知識(shí),本文通過(guò)圖文實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-09-09
Java中double數(shù)值保留兩位小數(shù)的4種實(shí)現(xiàn)方式舉例
在Java編程中,我們經(jīng)常遇到需要對(duì)double類型的浮點(diǎn)數(shù)進(jìn)行精確截?cái)嗷蛩纳嵛迦氡A魞晌恍?shù)的需求,這篇文章主要給大家介紹了關(guān)于Java中double數(shù)值保留兩位小數(shù)的4種實(shí)現(xiàn)方式,需要的朋友可以參考下2024-07-07
基于java web獲取網(wǎng)頁(yè)訪問(wèn)次數(shù)代碼實(shí)例
這篇文章主要介紹了基于java web獲取網(wǎng)頁(yè)訪問(wèn)次數(shù)代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02
spring boot輸入數(shù)據(jù)校驗(yàn)(validation)的實(shí)現(xiàn)過(guò)程
web項(xiàng)目中,用戶的輸入總是被假定不安全不正確的,在被處理前需要做校驗(yàn)。本文介紹在spring boot項(xiàng)目中實(shí)現(xiàn)數(shù)據(jù)校驗(yàn)的過(guò)程,通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-09-09

