【springboot+easypoi】一行代码搞定简单的word导出

之前写过一篇《一行代码搞定Excel导入导出》,有需要的童鞋可以回头看一下,今天简单说一下怎么一行代码实现简单的word导出。有的童鞋不太同意了,扯淡呢一行代码。你说的对,不是一行,但是封装后每次调用的时候再看是什么情况。^^_^^

1、像之前一样的引入easypoi的pom

       <dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-base</artifactId>
            <version>3.0.3</version>
        </dependency>
        <dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-web</artifactId>
            <version>3.0.3</version>
        </dependency>
        <dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-annotation</artifactId>
            <version>3.0.3</version>
        </dependency>

2、工具类封装

 /**
     * 导出word
     * <p>第一步生成替换后的word文件,只支持docx</p>
     * <p>第二步下载生成的文件</p>
     * <p>第三步删除生成的临时文件</p>
     * 模版变量中变量格式:{{foo}}
     * @param templatePath word模板地址
     * @param temDir 生成临时文件存放地址
     * @param fileName 文件名
     * @param params 替换的参数
     * @param request HttpServletRequest
     * @param response HttpServletResponse
     */
    public static void exportWord(String templatePath, String temDir, String fileName, Map<String, Object> params, HttpServletRequest request, HttpServletResponse response) {
        Assert.notNull(templatePath,"模板路径不能为空");
        Assert.notNull(temDir,"临时文件路径不能为空");
        Assert.notNull(fileName,"导出文件名不能为空");
        Assert.isTrue(fileName.endsWith(".docx"),"word导出请使用docx格式");
        if (!temDir.endsWith("/")){
            temDir = temDir + File.separator;
        }
        File dir = new File(temDir);
        if (!dir.exists()) {
            dir.mkdirs();
        }
        try {
            String userAgent = request.getHeader("user-agent").toLowerCase();
            if (userAgent.contains("msie") || userAgent.contains("like gecko")) {
                fileName = URLEncoder.encode(fileName, "UTF-8");
            } else {
                fileName = new String(fileName.getBytes("utf-8"), "ISO-8859-1");
            }
            XWPFDocument doc = WordExportUtil.exportWord07(templatePath, params);
            String tmpPath = temDir + fileName;
            FileOutputStream fos = new FileOutputStream(tmpPath);
            doc.write(fos);
            // 设置强制下载不打开
            response.setContentType("application/force-download");
            // 设置文件名
            response.addHeader("Content-Disposition", "attachment;fileName=" + fileName);
            OutputStream out = response.getOutputStream();
            doc.write(out);
            out.close();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            delAllFile(temDir);//这一步看具体需求,要不要删
        }

    }

3、调用测试

1.在项目下找个地方放模板文件
word.docx
2.确定临时生成文件的存放路径
3.controller调用(这里有我说的一行代码)

import com.df.commons.utils.FileUtil;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.File;
import java.util.HashMap;
import java.util.Map;

@Controller
@RequestMapping("demo")
public class TestController {

    @RequestMapping("export")
    public void export(HttpServletRequest request, HttpServletResponse response){
        Map<String,Object> params = new HashMap<>();
        params.put("title","这是标题");
        params.put("name","李四");
        //这里是我说的一行代码
        FileUtil.exportWord("word/export.docx","F:/test","aaa.docx",params,request,response);
    }
}

4、模版格式

我只是这里写成了表格,你可以用任意格式,只需要替换变量即可。
模板.png
导出结果.png

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 17
    评论
好的,关于你的问题,我会为你详细介绍SpringBootEasyPoi如何实现数据导出。下面是实现步骤及代码示例: 步骤1:在pom.xml中添加EasyPoi依赖 ```xml <dependency> <groupId>cn.afterturn</groupId> <artifactId>easypoi-base</artifactId> <version>4.2.0</version> </dependency> ``` 步骤2:定义导出的实体类,并使用注解配置导出的列名和顺序 ```java public class User{ @Excel(name = "用户名", orderNum = "1") private String username; @Excel(name = "密码", orderNum = "2") private String password; // ...其他属性及getter/setter方法 } ``` 步骤3:编写导出Excel数据的控制器 ```java @RestController @RequestMapping("/api/user") public class UserController { @Autowired private UserService userService; @GetMapping("/export") public void exportData(@RequestParam(name = "fields") String fields, HttpServletResponse response) { // 处理表头列名 String[] titles = fields.split(","); // 查询数据库中所有用户信息 List<User> userList = userService.findAll(); // 根据用户选择的字段过滤掉不需要导出的列 for (int i = 0; i < titles.length; i++) { boolean isMatch = false; for (Field field : User.class.getDeclaredFields()) { if (field.isAnnotationPresent(Excel.class)) { Excel annotation = field.getAnnotation(Excel.class); if (annotation.name().equals(titles[i])) { isMatch = true; break; } } } if (!isMatch) { titles[i] = null; } } // 利用EasyPoi导出Excel ExportParams exportParams = new ExportParams("", "用户信息"); exportParams.setCreateHeadRows(true); exportParams.setHeadRows(1); Workbook workbook = ExcelExportUtil.exportExcel(exportParams, User.class, userList, null, titles, null); try (OutputStream outputStream = response.getOutputStream()) { response.setCharacterEncoding("UTF-8"); response.setHeader("Content-Disposition", "attachment;filename=" + java.net.URLEncoder.encode("用户信息.xlsx")); workbook.write(outputStream); } catch (IOException e) { e.printStackTrace(); } } } ``` 以上就是导出Excel的完整代码,其中针对用户选择需要导出的字段进行校验的部分,使用了反射机制获取注解信息进行匹配。为保证Excel格式的一致性,我们还使用了EasyPoi提供的ExportParams配置Excel表头等属性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值