springboot+freemarker实现动态表格输出

文章展示了如何在SpringBoot项目中集成Freemarker和Thymeleaf模板引擎,创建了一个User实体类,并提供了生成HTML的Utils工具类。在Controller中测试了从数据到HTML的转换过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.添加依赖:

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-freemarker</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>

2.创建测试实体

import lombok.Data;
import java.io.Serializable;

@Data
public class User implements Serializable {
    private int id;
    private String name;
    private int age;
}

3. 创建 html 转 string 的 Utils

import freemarker.template.Configuration;
import freemarker.template.Template;
import freemarker.template.TemplateException;

import java.io.File;
import java.io.IOException;
import java.io.StringWriter;
import java.util.Map;

public class MakeHtmlUtils {

    /**
     * 生成带数据的html
     * @param data 数据
     * @param fileName html文件名
     * @return
     */
    public static String MakeHtml(Map<String, Object> data, String fileName){
        // 第一步:创建一个Configuration对象。
        Configuration configuration = new Configuration(Configuration.getVersion());
        // 创建一个Writer对象。
        StringWriter out = new StringWriter();
        try {
            // 第二步:设置模板文件所在的路径。
            configuration.setDirectoryForTemplateLoading(new File("D:\\workspace\\communicate\\communicate-api\\src\\main\\resources\\templates"));
            // 第三步:设置模板文件使用的字符集。
            configuration.setDefaultEncoding("utf-8");
            // 第四步:加载一个模板,创建一个模板对象。
            Template template = configuration.getTemplate(fileName);
            // 第五步:调用模板对象的process将数据塞入模板中。
            template.process(data, out);
            //返回处理好的HTML字符串
            return out.toString();
        } catch (IOException | TemplateException e) {
            return "error";
        } finally {
            try {
                out.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }

    }


}

4.controller测试类

import com.alibaba.fastjson.JSONArray;
import com.geely.office.im.common.util.MakeHtmlUtils;
import com.geely.office.im.model.entity.AdsFinancingCompanyAllIndexesDfPo;
import com.geely.office.im.model.entity.DataAuditVo;
import com.geely.office.im.model.entity.User;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import java.util.*;

@Controller
public class UserController {

    @GetMapping("/msg")
    @ResponseBody
    public String index(){

        List<User> users = new ArrayList<>();

        for (int i = 0; i < 6; i++) {
            User user = new User();
            user.setId(i);
            user.setName("liudy"+i);
            user.setAge(18);
            users.add(user);
        }

        Map<String, Object> data = new HashMap<>();
        data.put("users", users);
        data.put("group1", "班级一");

        String result = MakeHtmlUtils.MakeHtml(data, "user.html");

        return result;
    }
}

5.访问测试地址(测试效果)

 

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 ……
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值