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

如需客户端指定excel版本,只需要判断后缀名然后在controller中的.excelType(ExcelTypeEnum.XLS)做指定输出内容格式即可

***(注意表格行高列宽统一设置是在实体类的类名注解上,如果需要对表格进行精细的宽高设置需要删除掉这两个注解,可以在拦截器使用row的方法进行设置)

1. ## 引入依赖

com.alibaba

easyexcel

2.1.4

2.实体类(注解法)

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 = {"序号","序号"},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 = {"建筑垃圾堆存量(万方)","建筑垃圾堆存量(万方)"},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 = {"如需外运,计划外运时间","如需外运,计划外运时间"},index = 8)

@ColumnWidth(15)

private String outwardtransporttime;

@ExcelProperty(value = {"截止目前累计治理量(万方)","截止目前累计治理量(万方)"},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 = {"监管单位","监管单位"},index = 15)

@ColumnWidth(15)

private String supervisedepartname;

@ExcelProperty(value = {"监管责任人","监管责任人"},index = 16)

@ColumnWidth(10)

private String supervisepeoname;

@ExcelProperty(value = {"职务","职务"},index = 17)

@ColumnWidth(10)

private String supervisepeoposition;

@ExcelProperty(value = {"联系方式","联系方式"},index = 18)

@ColumnWidth(20)

private String supervisepeophone;

@ExcelIgnore

private String residuenum;

@ExcelIgnore

private String governendtime;

@ExcelIgnore

private String governendyearmonth;

@ExcelProperty(value = {"本月治理量(万方)","外运量"},index = 9)

@ColumnWidth(15)

private String outwardtransportnum;

@ExcelProperty(value = {"本月治理量(万方)","整理地形绿化量"},index = 10)

@ColumnWidth(15)

private String afforestnum;

@ExcelProperty(value = {"本月治理量(万方)","临时覆盖或绿化量"},index = 11)

@ColumnWidth(15)

private String temporarilynum ;

@ExcelProperty(value = {"本月治理量(万方)","合计"},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);

//设置序号

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可以防止中文乱码 当然和easyexcel没有关系

String fileName = URLEncoder.encode(“存量建筑垃圾堆体治理进度月报表”, “UTF-8”);

response.setHeader(“Content-disposition”, “attachment;filename=” + fileName + “.xls”);

//内容样式策略

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);

//设置 自动换行

contentWriteCellStyle.setWrapped(true);

// 字体策略

WriteFont contentWriteFont = new WriteFont();

// 字体大小

contentWriteFont.setFontHeightInPoints((short) 12);

contentWriteCellStyle.setWriteFont(contentWriteFont);

//头策略使用默认

WriteCellStyle headWriteCellStyle = new WriteCellStyle();

//excel如需下载到本地,只需要将response.getOutputStream()换成File即可(注释掉以上response代码)

EasyExcel.write(response.getOutputStream(), PilebodycheckMonthDto.class)

//设置输出excel版本,不设置默认为xlsx

.excelType(ExcelTypeEnum.XLS).head(PilebodycheckMonthDto.class)

//设置拦截器或自定义样式

.registerWriteHandler(new MonthSheetWriteHandler())

.registerWriteHandler(new HorizontalCellStyleStrategy(headWriteCellStyle,contentWriteCellStyle))

.sheet("存量建筑垃圾堆体治理进度月报表")

//设置默认样式及写入头信息开始的行数

.useDefaultStyle(true).relativeHeadRowIndex(3)

//这里的addsumColomn方法是个添加合计的方法,可删除

.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);

//设置单元格内容

cell.setCellValue("附件2");

//设置标题

Row row2 = sheet.createRow(1);

row2.setHeight((short) 800);

Cell cell1 = row2.createCell(0);

cell1.setCellValue("存量建筑垃圾堆体治理进度月报表");

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));

//设置填表日期,填报人,联系方式

Row row3 = sheet.createRow(2);

row3.setHeight((short) 500);

row3.createCell(1).setCellValue("填表日期");

row3.createCell(11).setCellValue("填表人");

row3.createCell(15).setCellValue("联系方式");

}

}

生成表格如下:

d8d653736426799ff326f91d585c3912.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/540066.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql distinct两列_正在检索两列,并对MySQL中的每列应用“distinct”

这是一张桌子books----------------------------| author_fname | author_lname |----------------------------| Dan | Harris || Freida | Harris || George | Saunders |----------------------------我知道如果DISTINCT用作SELECT DISTINCT author_fname, author_lname FRO…

mysql笛卡尔积 去重_MySQL入门(函数、条件、连接)

MySQL入门(四)distinct&#xff1a;去重mysql>:create table t1(id int,x int,y int);mysql>: insert into t1 values(1, 1, 1), (2, 1, 2), (3, 2, 2), (4, 2, 2);mysql>: select distinct * from t1; # 全部数据mysql>: select distinct x, y from t1; # 结果 1,…

nmon安装为什么重启mysql_Nmon的安装及使用

一、下载Nmon根据CPU的类型选择下载相应的版本&#xff1a;二、初始化工具[rootmululu ~]# cd /opt[rootmululu opt]# mkdir nmon[rootmululu opt]# cd nmon[rootmululu nmon]#wget http://sourceforge.net/projects/nmon/files/download/nmon_x86_12a.zip[rootmululu nmon]# u…

mysql join 循环_关于mysql联表的内嵌循环操作nested loop join中on和where执行顺序问题...

mysql的理论依据没找到&#xff0c;个人理解是先执行where的过滤条件&#xff0c;先关联再过滤明显做的是无用功。oracle中倒是能在执行计划中看到&#xff0c;先执行的是过滤条件(下面代码中最后一行)。explain plan for SELECT * FROM tmp_t2 t2 LEFT JOIN tmp_t1 t1 ON t2.i…

python非法语句是_python 如何优雅的处理大量异常语句?

bs4的链式调用很赞&#xff0c;所以我把soup包装了一下class MY_SOUP():包装类def __init__(self,soup):self.soup soupif soup:if soup.string:self.string soup.string.strip()else:self.string Noneelse:self.string Nonedef find(self, *args, **kw):ret self.soup.fi…

Iptables详解+实例

2019独角兽企业重金招聘Python工程师标准>>> Iptabels是与Linux内核集成的包过滤防火墙系统&#xff0c;几乎所有的linux发行版本都会包含Iptables的功能。如果 Linux 系统连接到因特网或 LAN、服务器或连接 LAN 和因特网的代理服务器&#xff0c; 则Iptables有利于…

django ipython shell_通過django的shell_plus編寫ipython腳本

Im writing a shell script which runs a command through ipython with the -c option like this:我正在編寫一個shell腳本&#xff0c;它通過ipython運行一個命令&#xff0c;使用-c選項&#xff0c;如下所示:ipython -c "from blah import myfunct; myfunct()"but…

阿里云服务器安装onlyoffice_阿里云服务器安装 JDK 8

欢迎关注“科技毒瘤君”&#xff01;上一期给大家分享了如何申请阿里云的免费云服务器&#xff0c;还没有看过的小伙伴可以先前往了解 >>阿里云免费服务器<<这一次将会为大家分享如何在服务器上配置 Java环境&#xff0c;这里演示使用的系统为Ubuntu 18.04 64位&am…

js发送请求

1.Chrome控制台中 net::ERR_CONNECTION_REFUSED js频繁发送请求&#xff0c;有可能连接被拒绝&#xff0c;可用setTimeout&#xff0c;过几秒发送&#xff0c;给个缓冲时间 var overlayAnalystService L.supermap.spatialAnalystService(serviceUrl); setTimeout(function () …

据说有99%的人都会做错的面试题

这道题主要考察了面试者对浮点数存储格式的理解。另外&#xff0c;请不要讨论该题本身是否有意义之类的话题。本题只为了测试面试者相关的知识是否掌握&#xff0c;题目本身并没有实际的意义。 下面有6个浮点类型变量&#xff0c;其中前三个是float类型的&#xff0c;后三个是d…

php使用mysql5和8的区别_mysql8.0和mysql5.7的区别是什么?

区别&#xff1a;mysql8.0的索引可以被隐藏和显示&#xff0c;当一个索引隐藏时&#xff0c;他不会被查询优化器所使用&#xff1b;2、mysql8.0新增了“SET PERSIST”命令&#xff1b;3、从mysql8.0开始&#xff0c;数据库的缺省编码将改为utf8mb4&#xff0c;包含了所有emoji字…

mysql pt check sum_percona工具pt-table-checksum

利用pt-table-checksum进行数据库同步检查rpm方式#wget percona.com/get/percona-toolkit.rpm源码方式#wget http://www.percona.com/downloads/percona-toolkit/2.2.1/percona-toolkit-2.2.8.tar.gz#yum install perl perl-CPAN perl-DBD-MySQL perl-Time-HiRes解压&#xff0…

如何通过BBED找回删除数据

项目案例&#xff1a;客户删除delete了重要数据&#xff0c;无备份&#xff0c;客户联系我&#xff0c;要求恢复相应数据。本次通过实验方式重现客户现场。备份高于一切&#xff0c;首先备份&#xff0c;再操作 创建表格&#xff1a; create table king(age number,name varcha…

mysql 重置密码语音_数字语音信号处理学习笔记语音信号的同态处理(2)

5.4 复倒谱和倒谱 定义 设信号x(n)的z变换为X(z) z[x(n)]&#xff0c;其对数为&#xff1a; (1) 那么 的逆z变换可写成&#xff1a; (2) 取 (1)式则有 (3) 于是式子(2)则可以写成 (4) 则式子(4)即为信号x(n)的复倒谱 的定义。因为 一般为复数&#xff0c;故称 为复倒谱。如果对…

NFS 八步神曲

Server:第一步yum install - y nfs*第二步vi /etc/exports第三步/var/testdirs *(rw,all_squash,anonuid99,anongid99,sync)第四步service nfs start第五步chkconfig --level 35 nfs on Client第一步mount 192.168.1.X:/var/www/testdirs /var/www/testdirs第二步vi /et…

mysql权限日志_mysql权限管理、日志管理及常用工具

mysqlbinlog用法如下&#xff1a;mysqbinlog mysql.err 查询错误日志当然可以通过添加参数来查看指定内容,如&#xff1a;mysqlbinlog mysql-bin.000001 -d test 只显示对test数据库的二进制日志mysqlbinlog mysql-bin.000001 -o 3 -r result-file 首先忽略前三个操作&…

Juicer.js模板引擎问题

由于jsp中的EL表达式语法和jquery.tmpl十分类似&#xff0c;&#xff0c;所以单纯的使用${name}&#xff0c;数据是渲染不上tmpl的. SO.. 要加上转义: ${${}amount} 或者 \${amount} 转载于:https://www.cnblogs.com/fighxp/p/7890288.html

python把回车作为输入_python将回车作为输入内容的实例

当input输入内容的时候,许多情况下输入回车键另起一行输入,但是这时候Pycharm就执行程序,然后结束,导致无法继续输入内容。 原因:Python默认遇到回车的时候,输入结束。所以我们需要更改这个提示符,在遇到其他字符的时候,输入才结束。 比如有一个任务: 请输入文件名:悯…

ubuntu下修改时区和时间

applications-Accessories-Time & Date-点下锁-输入密码-把时区改成上海&#xff08;这个要点图中国与朝鲜之间的弯处才行&#xff0c;写不生效&#xff09;-Set the time 选Manually-改下时间、日期-直接关闭即可(重启后依然生效) 注&#xff1a;从电脑上边的时间处-Time …