看固定模板的設(shè)置格式是這樣的
public class FourListExcelDto {
@ContentStyle(dataFormat = 14)
@DateTimeFormat("yyyy/M/dd")
@ExcelProperty({"時(shí)間"})
private Date exportDate;
}
但是非固定模板的是根據(jù)你來(lái)的數(shù)據(jù)來(lái)生成文件的這樣就無(wú)法使用了。
用EasyExcel.write(outputStream).registerWriteHandler(xxx).doWrite(data)生成文件,我們可以自己實(shí)現(xiàn)一個(gè)registerWriteHandler,去格式化單元格。
新建Handler類,繼承AbstractCellStyleStrategy
public class ExcelCellStyleStrategy extends AbstractCellStyleStrategy {
/**
* 單元格格式列表(格式:GENERAL、CURRENCY_¥、CURRENCY_$、DATE、NUMERIC)
*/
private final List<String> cellDataTypes;
/**
* WorkBoot
*/
private Workbook workbook;
/**
* 構(gòu)造方法,創(chuàng)建對(duì)象時(shí)傳入需要定制的表頭信息隊(duì)列
*/
public ExcelCellStyleStrategy(List<String> cellDataTypes) {
this.cellDataTypes = cellDataTypes;
}
@Override
protected void initCellStyle(Workbook workbook) {
// 初始化信息時(shí),保存Workbook對(duì)象,轉(zhuǎn)換時(shí)需要使用
this.workbook = workbook;
}
@Override
protected void setHeadCellStyle(Cell cell, Head head, Integer relativeRowIndex) {
// 處理表頭的
}
@Override
protected void setContentCellStyle(Cell cell, Head head, Integer relativeRowIndex) {
CellStyle cellStyle = workbook.createCellStyle();
String cellValue = cell.getStringCellValue();
String dataTypes = cellDataTypes.get(head.getColumnIndex());
switch (dataTypes) {
case "DATE":
// 時(shí)間
if (StrUtil.isNotBlank(cellValue)) {
DateTime dateTime = DateUtil.parseDateTime(cellValue);
cell.setCellValue(DateUtil.format(dateTime, "yyyy/m/d h:mm"));
cellStyle.setDataFormat((short) 164);
}
break;
case "NUMERIC":
// 數(shù)字
cell.setCellType(CellType.NUMERIC);
// cellStyle.setDataFormat((short) 1);
// 自定義格式
// 1 -> "0", 表示整數(shù)
// 2 -> "0.00", 表示浮點(diǎn)數(shù)
// 3 -> "#,##0", 表示三個(gè)數(shù)字加一個(gè)","格式的整數(shù)
// 4 -> "#,##0.00", 表示三個(gè)數(shù)字加一個(gè)","格式的浮點(diǎn)數(shù)
if (StrUtil.isBlank(cellValue)) {
cell.setCellValue("");
} else {
cell.setCellValue(Integer.parseInt(cellValue));
}
break;
default:
if (dataTypes.startsWith("CURRENCY_")) {
// 貨幣
String currency = dataTypes.substring(9);
cell.setCellValue(StrUtil.format("{}{}", currency, StrUtil.isBlank(cellValue) ? "-" : cellValue));
cellStyle.setDataFormat((short) 42);
}
// 默認(rèn)是通用類型,無(wú)需額外處理
}
cell.setCellStyle(cellStyle);
}
}
主要看setContentCellStyle方法,創(chuàng)建ExcelCellStyleStrategy時(shí)需要把每一列的數(shù)據(jù)類型傳遞過(guò)來(lái)。
cellStyle.setDataFormat這個(gè)有意思,可以好好研究一下。
easypoi支持的自定義格式列表
BuiltinFormats類的_formats列表里的自定義格式才有效,否則就會(huì)使用文本格式。
記錄數(shù)據(jù)類型就根據(jù)你實(shí)際情況來(lái)寫了,下面時(shí)我這邊的。根據(jù)業(yè)務(wù)來(lái)寫的,別無(wú)腦跟!
設(shè)置效果
貨幣
日期
唯重
關(guān)注
————————————————
版權(quán)聲明:本文為CSDN博主「唯重」的原創(chuàng)文章,遵循CC 4.0 BY-SA版權(quán)協(xié)議,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/GMingZhou/article/details/124149506
聯(lián)系客服