poi-tl导出word和easypoi导出excel笔记,包括word的循环列表,双层循环

现在有个需求,需要导出接口文档,有word和excel两种文档。
excel相对简单,现在poi对excel的支持很成熟了,网上案例也很多,我这里用的easypoi,注解形式放到实体类的字段上,就不多说excel的了。
导出word时,word需要动态生成每个接口的信息,每个接口中要动态生成每个对象参数列表,其实需求也不算复杂。
我先后用了easypoi和esayword,这两个都特别坑,导出的时候各种问题,特别是easyword,要用书签的形式,word模板动不动就不能生效。后来干脆放弃改用了poi-tl。不得不说这个对word导出的技术还是挺完善、成熟的。
标签的含义网上一堆,全是cv的官网的。。。
模板:所有的()为注释,实际模板使用记得要去掉,word的样式可以在模板里设置好,代码也可以设置,不过麻烦点。
{ {?interfaceInfos}}(区块对标签,就是循环生成接口信息)

2.{ {interfaceInfoVO.sort}} { {interfaceInfoVO.name}}
基本信息
接口名称 { {interfaceInfoVO.name}}
接口描述 { {interfaceInfoVO.describe}}
数据格式 { {interfaceInfoVO.dataType}}
请求方式 { {interfaceInfoVO.requestType}}
接口URL { {interfaceInfoVO.url}}
其他
服务编码 { {interfaceInfoVO.code}}
设计负责人 { {interfaceInfoVO.designerName}}
开发负责人 { {interfaceInfoVO.developer}}
测试负责人 { {interfaceInfoVO.tester}}

入参描述
{ {interfaceParamInList}}属性名称 类型 最大长度 是否必填 属性中文名称 属性备注 示例值
[enName] [type] [length] [requiredName] [cnName] [describe]

{ {?inParam}}(参数区块对,参数为对象时,要循环生成每个对象的列表)
{ {inFieldName}}对象描述
{ {inList}}属性名称 类型 最大长度 是否必填 属性中文名称 属性备注 示例值
[enN

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SpringBoot_Freemarker生成Word_多个表格+两层嵌套循环; 步骤说明: 1.用Microsoft Office Word打开word原件;将文档中需要动态生成的内容,替换为属性名 ${name} 2.另存为,选择保存类型Word 2003 XML 文档(*.xml) 3.用Firstobject free XML editor打开文件,选择Tools下的Indent【或者按快捷键F8】格式化文件内容。左边是文档结构,右边是文档内容; 4. 文档生成后有时需要手动修改,查找第一步中设置的属性名,可能会产生类似${n.....ame}类似的样子,我们将将名字中间的标签删掉,恢复为${name} 5. word模板中有表格,需要循环的位置, 用 标签将第二对 标签(即除表头的w:tr标签后的一对)包围起来 同时表格内的属性例如${name},在这里需要修改为${user.name} (userList是集合在dataMap中的key, user是集合中的每个元素, 类似), 如图: PLUS:若表格之外还有嵌套的循环,也需要用,注意这里的标签不要和某对其他标签交叉,不可以出现这种 6. 标识替换完之后,另存为.ftl后缀文件即可。 代码里是相对有一丢丢复杂的,两层嵌套循环; 总(dataMap) deptName 部门名 list(Table)表的集合 table1(map) table-名字 ${map.table} tableName-中文名 ${map.tableName} columnCount-字段数 ${map.columnCount} recordCount-记录数 ${map.recordCount} listA-List--表格1 map.listA column Model属性——字段名 ${model.column} columnName Model属性——字段中文名 ${model.column} rate Model属性——字段占比 ${model.rate} nullValueCount Model属性——字段空值数 ${model.nullValueCount} listB-List--表格2 map.listB …… listC-List--表格3 map.listC …… table2 table-名字 ${map.table} tableName-中文名 ${map.tableName} columnCount-字段数 ${map.columnCount} recordCount-记录数 ${map.recordCount} listA-List--表格1 map.listA column Model属性——字段名 ${model.column} columnName Model属性——字段中文名 ${model.column} rate Model属性——字段占比 ${model.rate} nullValueCount Model属性——字段空值数 ${model.nullValueCount} listB-List--表格2 map.listB …… listC-List--表格3 map.listC …… table3 ……
poi-tl是一个基于POI的Java模板引擎,可以用于导出Word文档。在poi-tl中,可以使用foreach指令实现循环,并根据需要循环输出列表行和列。 在poi-tl中,可以将需要循环的数据存储在一个List对象中,然后使用foreach指令进行循环遍历。假设我们有一个List<RowData>对象,其中RowData是自定义的类,用于表示每一行的数据。RowData类中可以包含一些属性,代表每一行中的不同列。 首先,我们需要在Word模板中使用foreach指令,来循环输出列表行和列。可以使用标签${foreach items=listVar item=rowVar}和${end}将需要循环的部分包围起来。其中listVar是存储数据的List对象的名称,rowVar是循环过程中每一行数据的临时变量名。 然后,在foreach指令中,可以使用${rowVar.property}的方式获取每一行的属性值,来完成对列表行和列的输出。property代表RowData类中的某一个属性的名称。 最后,使用poi-tl提供的模板渲染引擎,将数据填充到Word模板中,生成目标Word文档。 综上所述,利用poi-tl可以很方便地循环输出列表行和列。首先需要准备好存储数据的List对象,并在Word模板中使用foreach指令进行循环遍历。然后,在循环过程中使用${rowVar.property}的方式获取每一行的属性值,完成对列表行和列的输出。最终,使用poi-tl提供的模板渲染引擎将数据填充到Word模板中,生成目标Word文档。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值