标题 freemorker 模板使用的特殊情况,list循环嵌套,导出是带有图片,导出文字换行等

本文详细介绍了在使用Freemarker模板导出doc文件时,如何处理复杂的list循环嵌套和动态替换图片的问题。通过封装数据为list<List>类型,利用Freemarker的<#list>标签进行循环操作,实现表格数据的动态插入。针对图片替换,文章提供了ftl文件的修改方法,确保每条数据对应的图片能正确显示。此外,还分享了如何处理文字换行,使每条数据独立占据一行的技巧。
摘要由CSDN通过智能技术生成

标题 freemorker 模板使用的特殊情况,list循环嵌套,导出是带有图片,导出文字换行等

使用freemorker 导出 doc 时,简单赘述下:
首先 通过挖洞的形式 例如用 ${test} 作为变量,挖好我们需要导出的所有变量的值,
然后将文件另存为 word.xml ,之后格式化xml,将格式化后的xml文件转成ftl 文件,再ftl 文件中 进行 freemorker 的便签编写。

  1. 当需要导出的数据比较复杂时,会出现循环嵌套问题。
    解决方案:
    将需要导出的数据封装为list<List>类型 ,循环使用freemorker 中的标签<#list>进行循环,如图所示:在这里插入图片描述
    其中 后端的封装类型

在这里插入图片描述
这种 循环 一般用于在doc 中 插入表格,表格数据还不确定的情况,
而循环 嵌套循环 则 一般在于 整块数据 需要循环 而这块数据中 ,还有一个或是多个表格的情况
对于后台的封装数据有多种选择,我一般使用
第一层使用:List testArray = new ArrayList<>();
如果还需要循环
第二层使用:List test2Array = new ArrayList<>();
之后将其他数据和test2Array 一起add 到testArray 中。
这样第一个<#list>时,其他数据正常展示,test2Array 则需要在进行 <#list> 操作

  1. 当导出的doc ,其中包含有证件照或是普通图片时,动态的替换照片
    解决方法:
    主要还是ftl 文件的修改。具体的改动比较多,常规模式的参数写入就不一一赘述。只展示 当图片作为变量时的 ftl 文件的改动
    以下截图分为原版和改动两部分,请逐一改动
    第一处改动:
    原版:
    在这里插入图片描述
    改版
    在这里插入图片描述
    这里的使用<#list> 标签是遍历循环的常规操作,当然是因为我这里需要用到循环,只是单张图片替换,则不要照搬。rid 是指向,由于有多张图片,则rid不能写死,否则所有的图片只会显示第一张的图片样子。pxStudent 相当于for 循环中的 i ,_index 在这里是表示序号,是会自增的变量,不需要自己定义。

第二处改动:
原版:
在这里插入图片描述
改版:
在这里插入图片描述
这里的rid 主要是和上面的图片id 相对应,确定图片在模板中展示的位置。

第三处改动:
原版:在这里插入图片描述

改版:

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 ……
EasyExcel是一个Apache POI和Junit4驱动的优秀工具,它简化了Excel数据的读取和写入操作。当需要处理复杂的列表嵌套结构,比如List< List<T>>这样的数据时,可以借助`excelUtil`(可能是某个自定义的工具包或者是EasyExcel提供的辅助功能)来将其导出到Excel文件。 首先,你需要将复杂的列表结构转换成EasyExcel支持的数据模型,通常是一个普通的Java Bean对象或者Pojo类。然后,你可以创建一个模板 Excel 表格,其中包含适当的列标题,以对应你的数据结构。 接下来,使用`excelUtil`的方法,例如`write()`或者`doWrite()`, 将这个转换后的数据集写入Excel,通过遍历外层和内层列表逐行插入数据。EasyExcel会自动处理嵌套的数据,并按照你的配置顺序填充每一行。 示例代码可能会类似这样: ```java // 假设DataModel是个适配复杂结构的类 List<List<DataModel>> dataList = ...; // 要导出的数据 // 创建一个workbook和sheet Workbook workbook = new XSSFWorkbook(); Sheet sheet = workbook.createSheet("数据表"); // 写入头信息(假设DataModel有一个getHeader()方法返回列名) Row headerRow = sheet.createRow(0); for (Field field : DataModel.class.getDeclaredFields()) { Cell cell = headerRow.createCell(field.getIndex()); cell.setCellValue(field.getName()); } // 遍历并写入数据 int rowIndex = 1; for (List<DataModel> subList : dataList) { Row row = sheet.createRow(rowIndex++); for (DataModel model : subList) { for (Field field : model.getClass().getDeclaredFields()) { if (!field.isAccessible()) { field.setAccessible(true); } try { Cell cell = row.createCell(field.getIndex()); cell.setCellValue(field.get(model).toString()); } catch (IllegalAccessException e) { e.printStackTrace(); } } } } // 最后导出到文件 FileOutputStream outputStream = new FileOutputStream("output.xlsx"); workbook.write(outputStream); outputStream.close(); ```
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值