freemaker如何自动生成循环数据表格

1.在java中以HashMap<String,List<Object>>的形式组织数据

例如:

Map<String,Object> map=new HashMap<>();
map.put("name", "1111");
map.put("yy1", "1111");
List<SysUser> list=new ArrayList<SysUser>();
SysUser sysUser=new SysUser();
sysUser.setNickName("1");
sysUser.setPassword("1111");
sysUser.setPhoneNumber("123");
list.add(sysUser);
list.add(sysUser);
list.add(sysUser);
map.put("sys",list);

2.制作模板

   A.在表格中填写变量,nickName、password、phoneNumber是sysUser的类属性

  B.在ftl文件中需要循环的代码块增加list循环<#list sys as sysUser>.....</#list>

<#list sys as sysUser>
<w:tr wsp:rsidR="0020673F" wsp:rsidRPr="0020673F" wsp:rsidTr="0020673F"><w:tc><w:tcPr><w:tcW w:w="2765" w:type="dxa"/><w:shd w:val="clear" w:color="auto" w:fill="auto"/></w:tcPr><w:p wsp:rsidR="0020673F" wsp:rsidRPr="0020673F" wsp:rsidRDefault="0020673F" wsp:rsidP="0020673F"><w:pPr><w:pStyle w:val="HTML"/><w:shd w:val="clear" w:color="auto" w:fill="FFFFFF"/><w:rPr><w:rFonts w:ascii="Consolas" w:h-ansi="Consolas"/><wx:font wx:val="Consolas"/><w:color w:val="000000"/><w:sz w:val="20"/><w:sz-cs w:val="20"/></w:rPr></w:pPr><w:r><w:rPr><w:rFonts w:hint="fareast"/></w:rPr><w:t>${sysUser.nickName}</w:t></w:r></w:p></w:tc>
<w:tc><w:tcPr><w:tcW w:w="2765" w:type="dxa"/><w:shd w:val="clear" w:color="auto" w:fill="auto"/></w:tcPr><w:p wsp:rsidR="0020673F" wsp:rsidRPr="0020673F" wsp:rsidRDefault="0020673F" wsp:rsidP="0020673F"><w:r wsp:rsidRPr="0020673F"><w:rPr><w:rFonts w:hint="fareast"/></w:rPr><w:t>${sysUser.password}</w:t></w:r></w:p></w:tc>
<w:tc><w:tcPr><w:tcW w:w="2766" w:type="dxa"/><w:shd w:val="clear" w:color="auto" w:fill="auto"/></w:tcPr><w:p wsp:rsidR="0020673F" wsp:rsidRPr="0020673F" wsp:rsidRDefault="0020673F" wsp:rsidP="0020673F"><w:pPr><w:pStyle w:val="HTML"/><w:shd w:val="clear" w:color="auto" w:fill="FFFFFF"/><w:rPr><w:rFonts w:ascii="Consolas" w:h-ansi="Consolas"/><wx:font wx:val="Consolas"/><w:color w:val="000000"/><w:sz w:val="20"/><w:sz-cs w:val="20"/></w:rPr></w:pPr><w:r><w:rPr><w:rFonts w:hint="fareast"/></w:rPr><w:t>${sysUser.phoneNumber}</w:t></w:r></w:p></w:tc></w:tr>
</#list>

3.导出word

  public void createDoc(String templatePath,String savePath,Object object) throws Exception {


        configuration.setDirectoryForTemplateLoading(new File(new File(templatePath).getParent()+"/"));
        Template t=null;
        try {
            //test.ftl为要装载的模板
            t = configuration.getTemplate(new File(templatePath).getName());
        } catch (IOException e) {
            e.printStackTrace();
        }
        //输出文档路径及名称
        //File outFile = new File("C:\\Users\\Administrator\\Desktop\\test_new6.doc");
        File outFile = new File(savePath);
        if (!outFile.getParentFile().exists())
        {
            outFile.getParentFile().mkdirs();
            outFile.getParentFile().setExecutable(true);//设置可执行权限
            outFile.getParentFile().setReadable(true);//设置可读权限
            outFile.getParentFile().setWritable(true);//设置可写权限
        }
        if (!outFile.exists())
        {
            outFile.createNewFile();
            outFile.setExecutable(true);//设置可执行权限
            outFile.setReadable(true);//设置可读权限
            outFile.setWritable(true);//设置可写权限
        }
        Writer out = null;
        try {
            out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile), "utf-8"));
        } catch (Exception e) {

            e.printStackTrace();
        }
        try {
            t.process(object, out);
            out.close();
        } catch (TemplateException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 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 ……
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值