freemarker导出word多表格嵌套到.ftl模板

freemarker导出word模板(对象包含list类型属性)

效果预览

这里只展示部分效果,实际根据.ftl模板有所不同。

在这里插入图片描述

准备工作

先准备写好的word模板,xml格式保存,替换文件类型为.flt。
可以使用foxe插件进行.ftl文件编译,设置带插入的值。
值:${}

导出的实体类

public class MarkerEntity {
    private String idx;
    private String freqName;
    private List<MarkerEntity> occupyList;
    //省略部分属性
}

数据集

//省略前端获取数据
String markerListJson = request.getParameter("markerListJson");
List<MarkerEntity> markerList = JSONArray.parseArray(markerListJson, MarkerEntity.class);
//设置数据集
Map<String, Object> map = new HashMap<String, Object>();
map.put("markerTbs", markerList);
//省略调用freemarker的api

.ftl格式的word模板表格绘制

<#-- 这里省略部分标题等其他模板内容 -->
<#-- 循环生成多个表格 -->
<#list markerTbs as marker>

	<#-- 这里可以设置表格的标题等 -->
	<w:p wsp:rsidR="000B4DD4" wsp:rsidRPr="005B7F94" wsp:rsidRDefault="000B4DD4">
	<w:pPr>
	<w:rPr>
	<w:rFonts w:ascii="宋体" w:fareast="宋体" w:h-ansi="宋体"/>
	<wx:font wx:val="宋体"/>
	<w:sz w:val="24"/>
	<w:sz-cs w:val="24"/>
	</w:rPr>
	</w:pPr>
	</w:p>
	<w:p wsp:rsidR="000B4DD4" wsp:rsidRPr="005B7F94" wsp:rsidRDefault="000B4DD4">
	<w:pPr>
	<w:rPr>
	<w:rFonts w:ascii="宋体" w:fareast="宋体" w:h-ansi="宋体"/>
	<wx:font wx:val="宋体"/>
	<w:sz w:val="24"/>
	<w:sz-cs w:val="24"/>
	</w:rPr>
	</w:pPr>
	<w:r wsp:rsidRPr="005B7F94">
	<w:rPr>
	<w:rFonts w:ascii="宋体" w:fareast="宋体" w:h-ansi="宋体"/>
	<wx:font wx:val="宋体"/>
	<w:sz w:val="24"/>
	<w:sz-cs w:val="24"/>
	</w:rPr>
	<w:t>${marker.idx}</w:t>
	</w:r>
	</w:p>
	
	<#-- 开始绘制表格模板 -->
	<w:tbl>
	<w:tblPr>
	<w:tblW w:w="0" w:type="auto"/>
	<w:tblBorders>
	<w:top w:val="single" w:sz="4" wx:bdrwidth="10" w:space="0" w:color="auto"/>
	<w:left w:val="single" w:sz="4" wx:bdrwidth="10" w:space="0" w:color="auto"/>
	<w:bottom w:val="single" w:sz="4" wx:bdrwidth="10" w:space="0" w:color="auto"/>
	<w:right w:val="single" w:sz="4" wx:bdrwidth="10" w:space="0" w:color="auto"/>
	<w:insideH w:val="single" w:sz="4" wx:bdrwidth="10" w:space="0" w:color="auto"/>
	<w:insideV w:val="single" w:sz="4" wx:bdrwidth="10" w:space="0" w:color="auto"/>
	</w:tblBorders>
	<w:tblLook w:val="04A0"/>
	</w:tblPr>
	<w:tblGrid>
	<w:gridCol w:w="936"/>
	<w:gridCol w:w="926"/>
	<w:gridCol w:w="926"/>
	<w:gridCol w:w="926"/>
	<w:gridCol w:w="926"/>
	<w:gridCol w:w="926"/>
	<w:gridCol w:w="926"/>
	<w:gridCol w:w="936"/>
	<w:gridCol w:w="889"/>
	</w:tblGrid>
	
	<#-- 这里是表格的首行:每个表格的字段自定义,这里只展示了1*n的表格,属性为"频率:freqName" -->
	<w:tr wsp:rsidR="00D060A0" wsp:rsidRPr="00D060A0" wsp:rsidTr="00D060A0">
	<w:tc>
	<w:tcPr>
	<w:tcW w:w="925" w:type="dxa"/>
	<w:shd w:val="clear" w:color="auto" w:fill="auto"/>
	</w:tcPr>
	<w:p wsp:rsidR="000B4DD4" wsp:rsidRPr="00D060A0" wsp:rsidRDefault="000B4DD4" wsp:rsidP="00D060A0">
	<w:pPr>
	<w:jc w:val="center"/>
	<w:rPr>
	<w:rFonts w:ascii="宋体" w:fareast="宋体" w:h-ansi="宋体"/>
	<wx:font wx:val="宋体"/>
	<w:sz w:val="18"/>
	<w:sz-cs w:val="18"/>
	</w:rPr>
	</w:pPr>
	<w:r wsp:rsidRPr="00D060A0">
	<w:rPr>
	<w:rFonts w:ascii="宋体" w:fareast="宋体" w:h-ansi="宋体" w:hint="fareast"/>
	<wx:font wx:val="宋体"/>
	<w:sz w:val="18"/>
	<w:sz-cs w:val="18"/>
	</w:rPr>
	<w:t>频率</w:t>
	</w:r>
	</w:p>
	</w:tc>
	</w:tr>
	
	<#-- 这里是重点,对象里包含list<T>属性,使用 marker.getOccupyList()继续遍历其中属性  -->
	<#list marker.getOccupyList() as col>
		<w:tr wsp:rsidR="00D060A0" wsp:rsidRPr="00D060A0" wsp:rsidTr="00D060A0">
		<w:tc>
		<w:tcPr>
		<w:tcW w:w="925" w:type="dxa"/>
		<w:shd w:val="clear" w:color="auto" w:fill="auto"/>
		</w:tcPr>
		<w:p wsp:rsidR="000B4DD4" wsp:rsidRPr="00D060A0" wsp:rsidRDefault="0041128C" wsp:rsidP="00D060A0">
		<w:pPr>
		<w:jc w:val="center"/>
		<w:rPr>
		<w:rFonts w:ascii="宋体" w:fareast="宋体" w:h-ansi="宋体"/>
		<wx:font wx:val="宋体"/>
		<w:sz w:val="18"/>
		<w:sz-cs w:val="18"/>
		</w:rPr>
		</w:pPr>
		<w:r wsp:rsidRPr="00D060A0">
		<w:rPr>
		<w:rFonts w:ascii="宋体" w:fareast="宋体" w:h-ansi="宋体"/>
		<wx:font wx:val="宋体"/>
		<w:sz w:val="18"/>
		<w:sz-cs w:val="18"/>
		</w:rPr>
		<w:t>${col.freqName}</w:t>
		</w:r>
		</w:p>
		</w:tc>
		</w:tr>
		
	</#list>

	</w:tbl>
	<w:p wsp:rsidR="000B4DD4" wsp:rsidRDefault="000B4DD4">
	<w:pPr>
	<w:rPr>
	<w:rFonts w:hint="fareast"/>
	</w:rPr>
	</w:pPr>
	</w:p>

</#list>
	
  • 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 ……
FreeMarker 是一个Java模板引擎,它可以帮助我们根据模板生成各种文件,包括 Word 文档。下面是一个简单的示例,演示如何使用 FreeMarker 创建一个根据 FTL 模板生成 Word 文档的过程: 1. 创建一个 FreeMarker 的配置对象,并设置模板文件所在的目录: ``` Configuration cfg = new Configuration(Configuration.VERSION_2_3_30); cfg.setDirectoryForTemplateLoading(new File("path/to/ftl/templates")); ``` 2. 从配置对象中获取模板对象: ``` Template template = cfg.getTemplate("template.ftl"); ``` 3. 准备数据模型,可以是一个 JavaBean、Map 或者其他类型的对象: ``` Map<String, Object> data = new HashMap<>(); data.put("title", "Hello, World!"); data.put("content", "This is a test document created by FreeMarker."); ``` 4. 创建一个 Writer 对象,用于输出生成的 Word 文档: ``` Writer out = new FileWriter(new File("path/to/output/doc.docx")); ``` 5. 将数据模型和 Writer 对象传递给模板对象,生成 Word 文档: ``` template.process(data, out); ``` 完整的示例代码如下: ``` import freemarker.template.Configuration; import freemarker.template.Template; import java.io.File; import java.io.FileWriter; import java.io.Writer; import java.util.HashMap; import java.util.Map; public class FreeMarkerDemo { public static void main(String[] args) throws Exception { // 创建 Configuration 对象 Configuration cfg = new Configuration(Configuration.VERSION_2_3_30); cfg.setDirectoryForTemplateLoading(new File("path/to/ftl/templates")); // 获取模板对象 Template template = cfg.getTemplate("template.ftl"); // 准备数据模型 Map<String, Object> data = new HashMap<>(); data.put("title", "Hello, World!"); data.put("content", "This is a test document created by FreeMarker."); // 创建输出流 Writer out = new FileWriter(new File("path/to/output/doc.docx")); // 生成 Word 文档 template.process(data, out); // 关闭输出流 out.close(); } } ``` 注意,上面的示例代码中使用的模板文件是 FTL 格式,如果要生成 Word 文档,还需要将模板文件转换成 docx 或者其他 Word 文档格式。常见的工具包括 Apache POI 和 Docx4j 等。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值