解决Poi-tl动态生成表格(行列都不确定的情况)

2023-11-10 17:10

本文主要是介绍解决Poi-tl动态生成表格(行列都不确定的情况),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、新增策略DetailTablePolicy,继承于抽象表格策略DynamicTableRenderPolicy

/*** 自定义动态表格* 重写render方法*/
public class DetailTablePolicy extends DynamicTableRenderPolicy {@Overridepublic void render(XWPFTable table, Object data) throws Exception {if(null == data) return;List<Map<String, Object>> targetRowData = (List<Map<String, Object>>) data;if(ObjectUtil.isNotEmpty(targetRowData) && targetRowData.size()>0){table.removeRow(0);//循环插入行数据for (int i = 0; i < targetRowData.size(); i++) {//第一行是标题行XWPFTableRow xwpfTableRow = table.insertNewTableRow(i);//循环列 row-cellBoolean flag = false;for (Map.Entry vo:targetRowData.get(i).entrySet()) {XWPFTableCell cell = xwpfTableRow.createCell();//单元格赋值cell.setText(vo.getValue().toString());//单元格文字居中CTTc cttc = cell.getCTTc();//文字垂直位置cttc.addNewTcPr().addNewVAlign().setVal(STVerticalJc.CENTER);//非标题行第一列文字居中,其他列文字居右if(i == 0){//文字水平位置cttc.getPList().get(0).addNewPPr().addNewJc().setVal(STJc.CENTER);}else{//文字水平位置if(flag == false){cttc.getPList().get(0).addNewPPr().addNewJc().setVal(STJc.CENTER);}else{cttc.getPList().get(0).addNewPPr().addNewJc().setVal(STJc.RIGHT);}}flag = true;}}}}}

2、调用我们重写的策略,report2.docx是我们的模板,模板里面的表格样式需要我们自定义,poi-tl技术主要针对的是数据处理问题

 

XWPFTemplate template = null;
InputStream templateInputStream = null;
File docFile = null;String fileName = "report2.docx";
templateInputStream = this.getClass().getClassLoader().getResourceAsStream("word/" + fileName);
if (null == templateInputStream) {return JsonBean.returnResponse(false, ResultCode.SERVER_ERROR, "模板文件不存在");
}
ConfigureBuilder builder = Configure.builder();
//配置为SpEL模式
builder.useSpringEL();
//除了标签前后缀外的任意字符
builder.buildGrammerRegex(RegexUtils.createGeneral("{{", "}}"));builder.bind("targetRowData",new DetailTablePolicy());template = XWPFTemplate.compile(templateInputStream, builder.build());
template.render(args);
//输出到文件
String dir ="路径";
String docName = "报告.docx";
docFile = new File(dir, docName);
template.writeToFile(docFile.getAbsolutePath());

这篇关于解决Poi-tl动态生成表格(行列都不确定的情况)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/384105

相关文章

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

Mysql DATETIME 毫秒坑的解决

《MysqlDATETIME毫秒坑的解决》本文主要介绍了MysqlDATETIME毫秒坑的解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 今天写代码突发一个诡异的 bug,代码逻辑大概如下。1. 新增退款单记录boolean save = s

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

解决Cron定时任务中Pytest脚本无法发送邮件的问题

《解决Cron定时任务中Pytest脚本无法发送邮件的问题》文章探讨解决在Cron定时任务中运行Pytest脚本时邮件发送失败的问题,先优化环境变量,再检查Pytest邮件配置,接着配置文件确保SMT... 目录引言1. 环境变量优化:确保Cron任务可以正确执行解决方案:1.1. 创建一个脚本1.2. 修

MYSQL行列转置方式

《MYSQL行列转置方式》本文介绍了如何使用MySQL和Navicat进行列转行操作,首先,创建了一个名为`grade`的表,并插入多条数据,然后,通过修改查询SQL语句,使用`CASE`和`IF`函... 目录mysql行列转置开始列转行之前的准备下面开始步入正题总结MYSQL行列转置环境准备:mysq