当前位置: 首页 > news >正文

java用easyexcel按模版导出

首先在项目的resources下面建一个template包,之后在下面创建一个模版,模版格式如下:

名称为 financeReportBillStandardTemplateExcel.xlsx:

{.fee}类型的属性值,是下面实体类的属性,要注意这里面的格式,不能错,还需要注意就是驼峰,例如:{.stockMv},要跟实体类的属性名保持一致,否则在导入的时候就会出现null之类的问题。

要是需要给属性设置格式之类的,例如:我们这里设置千分符并且保留两位小数,可进行如下图所示的操作,先选中所要设置的单元格,然后右键点击,选中设置单元格格式,就会弹出下图的操作,可以进行配置格式

接下来是实体类

package com.citicsc.galaxy.finance.lq;import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;import java.math.BigDecimal;
import java.util.Date;/*** @ClassName StandardBillFieldsDTO* @Description TODO* @Author houbing* @Date 2023/9/18 10:07*/@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class StandardBillFieldsDTO {private String id;//利息收入(利息归本)private BigDecimal interest;//股息红利private BigDecimal dividend;//资金余额private BigDecimal availableCash;//资产市值private BigDecimal assetMv;//非上市股票市值private BigDecimal unlistedMv;//当日国债逆回购发生额private BigDecimal debtReverseRepurchase;//出入金净额private BigDecimal netCash;//其他资金变动private BigDecimal otherCash;//总资金变动private BigDecimal totalCashInout;//交易费用private BigDecimal fee;//利息收入private BigDecimal interestIncome;//权利金收支private BigDecimal netPremium;//执行实收资金private BigDecimal realReceiveCash;//执行实付资金private BigDecimal realPaymentCash;//现金替代实收资金private BigDecimal realOffsetCashIn;//现金替代实付资金private BigDecimal realOffsetCashOut;//执行冻结资金private BigDecimal frozenCash;//市值权益private BigDecimal totalMv;//股票市值private BigDecimal stockMv;//买券金额private BigDecimal buySecuritiesAmount;//做市商交易经手费优惠private BigDecimal marketDiscount;//累计平仓盈亏private BigDecimal closePnl;//累计浮动盈亏private BigDecimal floatPnl;//其他交易费用private BigDecimal otherFee;}

这里只展示部分字段。

 接下来就直接在controller层中进行导出

@ApiOperation(value = "交易账户基础数据查询表")@PostMapping("/exportBill")public void exportBill(@RequestBody @Validated TraAccBillReq req ,HttpServletResponse response) throws Exception {response.setContentType("application/octet-stream");String fileName = URLEncoder.encode("交易账户基础数据查询表" + DateUtils.formatStr(req.getTradingDay()), "utf-8");response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");//查询数据库的数据List<StandardBillFieldsDTO> dtos = lqAppService.queryBillFieldList(req);if (CollectionUtils.isNotEmpty(dtos)) {FillConfig fillConfig = FillConfig.builder().forceNewRow(true).build();WriteSheet sheet = EasyExcel.writerSheet(0).build();ExcelWriter excelWriter = EasyExcel.write(response.getOutputStream()).withTemplate(new ClassPathResource("template/financeReportBillStandardTemplateExcel.xlsx").getInputStream()).build();excelWriter.fill(dtos, fillConfig, sheet);excelWriter.finish();} else {throw new BizException("未查询到账单信息");}}

http://www.lryc.cn/news/176136.html

相关文章:

  • Servlet执行流程生命周期方法介绍体系结构、Request和Response的功能详解
  • 软件工程之总体设计
  • 监控员工电脑文件拷贝记录:电脑怎么看员工复制文件的历史记录
  • vue中request.js中axios请求和(若依)文件通用下载方法封装
  • 【大数据存储与处理】1. hadoop单机伪分布安装和集群安装
  • linux通过time命令统计代码编译时间
  • logback日志是怎么保证多线程输出日志线程安全的
  • 2022年统计用区划代码表SQL 01
  • EM@基本初等函数@幂和根式@指数函数
  • 时序预测 | MATLAB实现NGO-GRU北方苍鹰算法优化门控循环单元时间序列预测
  • element 二次确认框,内容自定义处理
  • 【软件设计师-中级——刷题记录4(纯干货)】
  • 9.24 校招 实习 内推 面经
  • 第二章:25+ Python 数据操作教程(第二十五节用 PYTHON 和 R 制作祝福圣诞节)持续更新
  • 你是怎么理解自动化测试的?理解自动化测试的目的和本质
  • 二十六、MySQL并发事务问题:脏读/不可重复读/幻读
  • RK3588平台开发系列讲解(项目篇)视频监控之RTMP推流
  • http基础教程(超详细)
  • Vue3 <script setup> 单文件组件 组合式 API 相关语法
  • 为什么说网络安全是IT行业最后的红利?是风口行业?
  • DD5 进制转换
  • 操作系统权限提升(二十七)之数据库提权-MySQL MOF提权
  • springcloud:四、nacos介绍+启动+服务分级存储模型/集群+NacosRule负载均衡
  • 人生第一个java项目 学生管理系统
  • Oracle统计信息手动收集与修改
  • 鸿鹄工程项目管理系统 Spring Cloud+Spring Boot+Mybatis+Vue+ElementUI+前后端分离构建工程项目管理系统
  • ubuntu安装freeswitch 1.10.10
  • 什么类型的企业适合应用RPA?
  • LuatOS-SOC接口文档(air780E)-- fdb - kv数据库,掉电不丢数据
  • 世界500强都摒弃使用FTP的真实原因