Java生成word文档的示例详解
更新时间:2022年12月13日 14:32:10 作者:步尔斯特
这篇文章主要为大家详细介绍了如何利用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(); } }
到此这篇关于Java生成word文档的示例详解的文章就介绍到这了,更多相关Java生成word文档内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Spring Boot 整合JPA 数据模型关联使用操作(一对一、一对多、多对多)
这篇文章主要介绍了Spring Boot 整合JPA 数据模型关联操作(一对一、一对多、多对多),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2022-07-07Springboot整合Dubbo+Nacos实现RPC调用的示例代码
随着互联网技术的飞速发展,越来越多的企业和开发者开始关注微服务架构,Nacos是阿里巴巴开源的一个动态服务发现、配置管理和服务管理平台,本文讲解如何将Spring Boot与Dubbo和Nacos整合,实现RPC调用,需要的朋友可以参考下2024-02-02
最新评论