日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

easyexcel 设置标题_使用easyexcel完成复杂表头及标题的导出功能(自定义样式)

發(fā)布時(shí)間:2025/3/11 编程问答 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 easyexcel 设置标题_使用easyexcel完成复杂表头及标题的导出功能(自定义样式) 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

如需客戶端指定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)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。