easyexcel 设置标题_使用easyexcel完成复杂表头及标题的导出功能(自定义样式)
如需客戶端指定excel版本,只需要判斷后綴名然后在controller中的.excelType(ExcelTypeEnum.XLS)做指定輸出內(nèi)容格式即可
***(注意表格行高列寬統(tǒng)一設(shè)置是在實(shí)體類的類名注解上,如果需要對(duì)表格進(jìn)行精細(xì)的寬高設(shè)置需要?jiǎng)h除掉這兩個(gè)注解,可以在攔截器使用row的方法進(jìn)行設(shè)置)
1. ## 引入依賴
com.alibaba
easyexcel
2.1.4
2.實(shí)體類(注解法)
package com.jpxx.admin.pilebody.service.api.dto;
import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.write.style.ColumnWidth;
import com.alibaba.excel.annotation.write.style.ContentRowHeight;
import com.alibaba.excel.annotation.write.style.HeadRowHeight;
import com.alibaba.excel.util.StringUtils;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;
@Data
@NoArgsConstructor
@Accessors(chain = true)
@ContentRowHeight(45)
@HeadRowHeight(50)
public class PilebodycheckMonthDto {
@ExcelIgnore
private String id;
@ExcelIgnore
private String cityid;
@ExcelIgnore
private String districtid;
@ExcelProperty(value = {"序號(hào)","序號(hào)"},index = 0)
@ColumnWidth(10)
private String orderNum;
@ExcelProperty(value = {"堆體名稱","堆體名稱"},index = 1)
@ColumnWidth(15)
private String name;
@ExcelProperty(value = {"具體位置","具體位置"},index = 3)
@ColumnWidth(30)
private String address;
@ExcelProperty(value = {"占地面積(平方)","占地面積(平方)"},index = 4)
@ColumnWidth(15)
private String areastr;
@ExcelProperty(value = {"堆體高度(米)","堆體高度(米)"},index = 5)
@ColumnWidth(10)
private String heightstr;
@ExcelProperty(value = {"建筑垃圾堆存量(萬(wàn)方)","建筑垃圾堆存量(萬(wàn)方)"},index = 6)
@ColumnWidth(15)
private String stocknum;
@ExcelIgnore
@Dict(dicCode = "governway")
private String governway;
@ExcelProperty(value = {"治理方式","治理方式"},index = 7)
@ColumnWidth(20)
private String governwayname;
@ExcelProperty(value = {"如需外運(yùn),計(jì)劃外運(yùn)時(shí)間","如需外運(yùn),計(jì)劃外運(yùn)時(shí)間"},index = 8)
@ColumnWidth(15)
private String outwardtransporttime;
@ExcelProperty(value = {"截止目前累計(jì)治理量(萬(wàn)方)","截止目前累計(jì)治理量(萬(wàn)方)"},index = 13)
@ColumnWidth(15)
private String governnum;
@ExcelProperty(value = {"治理主體","治理主體"},index = 14)
@ColumnWidth(15)
private String governbody;
@ExcelIgnore
@Dict(dicCode = "typestr")
private String typestr;
@ExcelProperty(value = {"堆體類型","堆體類型"},index = 2)
@ColumnWidth(15)
private String typestrname;
@ExcelIgnore
@Dict(dicCode = "statestr")
private String statestr;
@ExcelIgnore
private String districtname;
@ExcelProperty(value = {"監(jiān)管單位","監(jiān)管單位"},index = 15)
@ColumnWidth(15)
private String supervisedepartname;
@ExcelProperty(value = {"監(jiān)管責(zé)任人","監(jiān)管責(zé)任人"},index = 16)
@ColumnWidth(10)
private String supervisepeoname;
@ExcelProperty(value = {"職務(wù)","職務(wù)"},index = 17)
@ColumnWidth(10)
private String supervisepeoposition;
@ExcelProperty(value = {"聯(lián)系方式","聯(lián)系方式"},index = 18)
@ColumnWidth(20)
private String supervisepeophone;
@ExcelIgnore
private String residuenum;
@ExcelIgnore
private String governendtime;
@ExcelIgnore
private String governendyearmonth;
@ExcelProperty(value = {"本月治理量(萬(wàn)方)","外運(yùn)量"},index = 9)
@ColumnWidth(15)
private String outwardtransportnum;
@ExcelProperty(value = {"本月治理量(萬(wàn)方)","整理地形綠化量"},index = 10)
@ColumnWidth(15)
private String afforestnum;
@ExcelProperty(value = {"本月治理量(萬(wàn)方)","臨時(shí)覆蓋或綠化量"},index = 11)
@ColumnWidth(15)
private String temporarilynum ;
@ExcelProperty(value = {"本月治理量(萬(wàn)方)","合計(jì)"},index = 12)
private String goverytotal;
@ExcelIgnore
private String qynum;
@ExcelIgnore
@Dict(dicCode = "sourcestr")
private String sourcestr;
@ExcelIgnore
private String createbyname;
}
controller
@postMapping(“pilebodystatisticsmonthexport”)
public WebApiResponse pilebodystatisticsmonthexport (HttpServletResponse response,String month) throws IOException {
List pilebodysList = pilebodycheckService.pilebodystatisticsmonth(sysDepartDto, month);
//設(shè)置序號(hào)
for (int i = 1;i <= pilebodysList.size();i++){
pilebodysList.get(i-1).setOrderNum(i+"");
}
response.setContentType(“application/vnd.ms-excel”);
response.setCharacterEncoding(“utf-8”);
// 這里URLEncoder.encode可以防止中文亂碼 當(dāng)然和easyexcel沒(méi)有關(guān)系
String fileName = URLEncoder.encode(“存量建筑垃圾堆體治理進(jìn)度月報(bào)表”, “UTF-8”);
response.setHeader(“Content-disposition”, “attachment;filename=” + fileName + “.xls”);
//內(nèi)容樣式策略
WriteCellStyle contentWriteCellStyle = new WriteCellStyle();
//垂直居中,水平居中
contentWriteCellStyle.setVerticalAlignment(VerticalAlignment.CENTER);
contentWriteCellStyle.setHorizontalAlignment(HorizontalAlignment.CENTER);
contentWriteCellStyle.setBorderLeft(BorderStyle.THIN);
contentWriteCellStyle.setBorderTop(BorderStyle.THIN);
contentWriteCellStyle.setBorderRight(BorderStyle.THIN);
contentWriteCellStyle.setBorderBottom(BorderStyle.THIN);
//設(shè)置 自動(dòng)換行
contentWriteCellStyle.setWrapped(true);
// 字體策略
WriteFont contentWriteFont = new WriteFont();
// 字體大小
contentWriteFont.setFontHeightInPoints((short) 12);
contentWriteCellStyle.setWriteFont(contentWriteFont);
//頭策略使用默認(rèn)
WriteCellStyle headWriteCellStyle = new WriteCellStyle();
//excel如需下載到本地,只需要將response.getOutputStream()換成File即可(注釋掉以上response代碼)
EasyExcel.write(response.getOutputStream(), PilebodycheckMonthDto.class)
//設(shè)置輸出excel版本,不設(shè)置默認(rèn)為xlsx
.excelType(ExcelTypeEnum.XLS).head(PilebodycheckMonthDto.class)
//設(shè)置攔截器或自定義樣式
.registerWriteHandler(new MonthSheetWriteHandler())
.registerWriteHandler(new HorizontalCellStyleStrategy(headWriteCellStyle,contentWriteCellStyle))
.sheet("存量建筑垃圾堆體治理進(jìn)度月報(bào)表")
//設(shè)置默認(rèn)樣式及寫入頭信息開(kāi)始的行數(shù)
.useDefaultStyle(true).relativeHeadRowIndex(3)
//這里的addsumColomn方法是個(gè)添加合計(jì)的方法,可刪除
.doWrite(pilebodycheckService.addSumColomn(pilebodysList));
return new WebApiResponse(200, "生成excel文件成功", null);
}
4. 攔截器
package com.jpxx.admin.pilebody.web.api;
import com.alibaba.excel.write.handler.SheetWriteHandler;
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
import com.alibaba.excel.write.metadata.holder.WriteWorkbookHolder;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.util.CellRangeAddress;
public class MonthSheetWriteHandler implements SheetWriteHandler {
@Override
public void beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {
}
@Override
public void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {
Workbook workbook = writeWorkbookHolder.getWorkbook();
Sheet sheet = workbook.getSheetAt(0);
Row row1 = sheet.createRow(0);
row1.setHeight((short) 500);
Cell cell = row1.createCell(0);
//設(shè)置單元格內(nèi)容
cell.setCellValue("附件2");
//設(shè)置標(biāo)題
Row row2 = sheet.createRow(1);
row2.setHeight((short) 800);
Cell cell1 = row2.createCell(0);
cell1.setCellValue("存量建筑垃圾堆體治理進(jìn)度月報(bào)表");
CellStyle cellStyle = workbook.createCellStyle();
cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);
cellStyle.setAlignment(HorizontalAlignment.CENTER);
Font font = workbook.createFont();
font.setBold(true);
font.setFontHeight((short) 400);
cellStyle.setFont(font);
cell1.setCellStyle(cellStyle);
sheet.addMergedRegionUnsafe(new CellRangeAddress(1, 1, 0, 17));
//設(shè)置填表日期,填報(bào)人,聯(lián)系方式
Row row3 = sheet.createRow(2);
row3.setHeight((short) 500);
row3.createCell(1).setCellValue("填表日期");
row3.createCell(11).setCellValue("填表人");
row3.createCell(15).setCellValue("聯(lián)系方式");
}
}
生成表格如下:
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來(lái)咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)總結(jié)
以上是生活随笔為你收集整理的easyexcel 设置标题_使用easyexcel完成复杂表头及标题的导出功能(自定义样式)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 计算机机房管理具体工作和职责,机房管理
- 下一篇: html 物流状态,使用css实现物流进