Java Web: 数据填充word模板并导出

问题

在我们做web开发的时候,经常会遇到将数据导出为固定模板的word或者excel,在这里介绍一个非常简单的模板导出工具。代码极其简单,实际使用仅需两行,就不多赘述了

使用

maven引用

    <dependencies>
        <!--word操作工具类-->
        <dependency>
            <groupId>com.deepoove</groupId>
            <artifactId>poi-tl</artifactId>
            <version>1.6.0-beta1</version>
        </dependency>
        <!-- javaEEApi,如果部署在tomcat容器中可以添加配置:<scope>provided</scope> -->
        <dependency>
            <groupId>javax</groupId>
            <artifactId>javaee-api</artifactId>
            <version>7.0</version>
        </dependency>
        <!--poi对excel2007以上版本的支持 -->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>4.1.2</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>4.1.2</version>
        </dependency>


    </dependencies>

代码实现

		//需要保存的文件名/保存地址
        String fileName = null;
        fileName = talk.getSid() + "-" + talk.getName();

		//将模板word转化为stream
        InputStream is = this.getClass().getResourceAsStream("/templates/talk/ceshi.docx");

		//将数据对象转为HashMap 或者自己组装
        HashMap<String,String > dataMap = JSONObject.parseObject(JSONObject.toJSONString(talk),HashMap.class);

        XWPFTemplate xwpfTemplate = null;
        //实际使用代码-----
        //数据替换
        xwpfTemplate = XWPFTemplate
                .compile(is)
                .render(dataMap);
        //数据保存
        xwpfTemplate.writeToFile(fileName+".docx");

word模板(注意word文件的版本,部分版本可能会报错)

在这里插入图片描述

Logo

DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。

更多推荐