Java生成word文档的示例详解
作者:步尔斯特 发布时间:2022-02-11 19:37:47
标签:Java,生成,word
目标
依赖
<!-- poi工具类-->
<dependency>
<groupId>com.deepoove</groupId>
<artifactId>poi-tl</artifactId>
<version>1.12.0</version>
</dependency>
模版
实体
实体类需要和模版内的动态字段对应
代码
@GetMapping(value = "/all")
@SneakyThrows
public void table(All all, HttpServletResponse response) {
/* 假数据 */
all.setCode("2022-12-ABC");
all.setBuyer("步尔斯特航天有限公司");
String[][] strings = new String[100][5];
for (int i = 0; i < 100; i++) {
strings[i] = new String[]{i + "", "黄金", "100", "人民币", "125"};
}
all.setTableArray(strings);
// 模版路径
String wordPath = "/Users/issavior/java/java/seckill-redis/test/src/main/resources/";
String modelName = "all.docx";
String c = "购买方(Buyer): \n" +
"名称(Name):" + all.getBuyer() + "\n" +
"地址(Address):杭州市余杭区大东路100号\n" +
"电话(Tel.):021-20855588\n" +
"\n" +
"销售方(Seller):\n" +
"名称(Name):杭州火箭制造有限公司\n" +
"地址(Address):杭州市余杭区大东路919号\n" +
"电话(Tel.):021-20855553\n" +
"开户行(Bank):中国农业银行杭州支行\n" +
"账号(Account No.):033270-00873333567";
// 手绘表格
// 表头
RowRenderData row0 = Rows.of(c, "", "", "", "").textBold().create();
RowRenderData row1 = Rows.of("序号", "名称", "数量", "货币", "价格").center().create();
int length = 0;
if (all.getTableArray() != null) {
length = all.getTableArray().length;
}
// 表格数据 加上2行表头 再加上最后一行总价
RowRenderData[] rowRenderData = new RowRenderData[length + 3];
rowRenderData[0] = row0;
rowRenderData[1] = row1;
// 计算价钱
BigDecimal totalPrice = new BigDecimal("0");
for (int i = 0; i < length; i++) {
rowRenderData[i + 2] = Rows.of(all.getTableArray()[i]).center().create();
String s = all.getTableArray()[i][4];
BigDecimal bigDecimal = new BigDecimal(s);
totalPrice = totalPrice.add(bigDecimal);
}
RowRenderData row4 = Rows.of("总价:" + totalPrice, "", "", "小写", totalPrice.toString()).center().create();
rowRenderData[rowRenderData.length - 1] = row4;
// 表格合并,根据坐标
MergeCellRule rule = MergeCellRule.builder().map(MergeCellRule.Grid.of(0, 0), MergeCellRule.Grid.of(0, 4)).
// map(MergeCellRule.Grid.of(0, 1), MergeCellRule.Grid.of(1, 1)).
// map(MergeCellRule.Grid.of(0, 2), MergeCellRule.Grid.of(0, 3)).
// map(MergeCellRule.Grid.of(0, 4), MergeCellRule.Grid.of(1, 4)).
map(MergeCellRule.Grid.of(rowRenderData.length - 1, 0), MergeCellRule.Grid.of(rowRenderData.length - 1, 2)).
build();
TableRenderData table = Tables.of(rowRenderData).mergeRule(rule).create();
// 数据封装
all.setTableRenderData(table);
// 传入模板模板地址+信息数据
XWPFTemplate template = XWPFTemplate.compile(wordPath + modelName).render(all);
// 指定下载的文件名--设置响应头
response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode("发票.docx", "UTF-8"));
response.setContentType("application/vnd.ms-excel;charset=UTF-8");
response.setHeader("Pragma", "no-cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expires", 0);
try {
OutputStream out = response.getOutputStream();
BufferedOutputStream bos = new BufferedOutputStream(out);
template.write(out);
bos.flush();
out.flush();
template.close();
} catch (IOException e) {
e.printStackTrace();
}
}
来源:https://blog.csdn.net/CSDN_SAVIOR/article/details/128299107


猜你喜欢
- 1.launch启动协程fun main() = runBlocking { launch { &
- 1基本输入输出 static void main(string[] args) { cons
- Properties属性文件中的值有等号和换行Spring配置Shiro的过滤器时,有个filterChainDefinitions属性,值
- 前不久,我们发布了《选择 .NET 的 n 个理由》。它提供了对平台的高层次概述,总结了各种组件和设计决策,并承诺对所涉及的领域发表更深入的
- /// <summary> /// 实体转换辅助类 /// </summary> public class Mode
- 前言在实现红黑树之前,我们先来了解一下符号表。符号表的描述借鉴了Algorithms第四版,详情在:https://algs4.cs.pri
- 目录1.概览2.自定义枚举方法3.使用 == 比较枚举类型4.在 switch 语句中使用枚举类型5.枚举类型的属性,方法和构造函数6.En
- 具体代码如下所示:package com.example.studyapplication.fragment;import android.
- 为什么需要在应用程序中增加渠道信息?Android应用的发布需要面对各种各样的市场,我们称之为渠道。有的时候,我们需要知道应用是从哪个渠道下
- 前几天在这里分享了手写 sql 分页查询实现分页,现在来看看使用 mybatis 分页插件 pagehepler 来实现分页使用分页插件的原
- 作者: juky_huang 事件的简单解释: 事件是对象发送的消息,以发信号通知操作的发生。操作可能是由用户交互(例如
- jar 包启动时指定配置文件 application.ymlnohup java -jar vPaas.jar --spring.confi
- 1.定义每一个函数都占用一段内存单元,它们有一个起始地址,指向函数入口地址的指针称为函数指针。2.语法指向函数的指针变量的一般定义形式为:数
- 一、ServerSocket1.为了方便调试,先创建一个界面用于显示客户端连接信息基于javafx包写的一个简单界面! javafx.sce
- 一、简介1.Apollo 是什么?Apollo(阿波罗)是携程框架部门研发的分布式配置中心。服务端基于Spring Boot和Spring
- 修改readme.txt文件如下:Git is a distributed version control system.Git is fr
- 前言前段时间在写RPC框架的时候用到了Kryo、Hessian、Protostuff三种序列化方式。但是当时因为急于实现功能,就只是简单的的
- 引言上文Android:实现一个自定义有限制区域的图例(角度自识别)涂鸦工具类(上)中我们已经实现了自定义View签名的功能,包含撤回、清除
- 这是同一个问题,Listview中点击item是会变颜色的,因为listview设置了默认的listselector,有一个默认的颜色,同理
- spring boot metrics是什么?针对应用监控指标暴露,spring boot有一套完整的解决方案,并且内置了好很多的指标收集器