在平时项目开发中,相信或多或少的都遇到过word导出的需求,这里整理一个比较全面的java word导出方法,希望可以跟大家一起交流学习。

创建word模板

1.1 新建一个word模板,并修改字段

2 将word文件另存为xml 格式,打开xml 格式文件,你会发现你刚刚编写的会变成这样。

这里推荐一个比较好用的编辑器 sublime 具体教程可以参考这一篇sublime

安装好之后,修改刚刚的xml文件。

把需要更改的变量都替换成${xxx}.改完后,把xml文档重命名成后缀为.ftl 的freemaker文件。

1.3 列表和分页

分页标签为

在word xml 格式中, 表示的就是整个文本内容。我这里的业务需求是不同的类型的内容分页打印,既然 表示整个文本内容,那么就可以在模板中写多个 ,不同的分类显示不同的word模板内容。我这里分了三类,就有三个不同的分页。

列表循环

如果你的模板中包含表格, 找到 标签,使用#list>指令 循环你的list 数据,然后使用 ${} 取到相应的值。

自此,ftl 模板部分全部写完,将ftl 文件放入你电脑的某个位置,接下来可以开开心心的写java代码部分。

2.java后台编写

思路 :1.编写读取ftl 模板以及参数的方法

2.查询你需要填入word的数据,放入map。注意map的key一定要跟你在ftl文件中填写的字段对应。

话不多说,直接上代码。

package cn.ys.common.utils;

import java.io.BufferedWriter;

import java.io.ByteArrayOutputStream;

import java.io.File;

import java.io.FileInputStream;

import java.io.FileNotFoundException;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.InputStream;

import java.io.OutputStreamWriter;

import java.io.PrintWriter;

import java.io.Writer;

import java.net.HttpURLConnection;

import java.net.URL;

import java.net.URLEncoder;

import java.util.Date;

import java.util.LinkedHashMap;

import java.util.Map;

import java.util.regex.Matcher;

import java.util.regex.Pattern;

import javax.servlet.ServletOutputStream;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import org.apache.commons.lang.StringUtils;

import org.apache.poi.POIXMLDocument;

import org.apache.poi.POIXMLTextExtractor;

import org.apache.poi.hwpf.HWPFDocument;

import org.apache.poi.hwpf.usermodel.Range;

import org.apache.poi.openxml4j.opc.OPCPackage;

import org.apache.poi.xwpf.extractor.XWPFWordExtractor;

import org.apache.poi.xwpf.usermodel.XWPFDocument;

import sun.misc.BASE64Encoder;

import cn.ys.common.web.HtmlMessage;

import com.google.common.collect.Maps;

import freemarker.template.Configuration;

import freemarker.template.Template;

import freemarker.template.TemplateException;

public class WordUtils {

private WordUtils() {

throw new AssertionError();

}

/**

*

* @param templateFolder 你的ftl文件位置

* @param ftlFile 你的ftl 文件名

* @param map 需要渲染 数据

* @param localPath 生成word文档的位置

* @param title word文档名

* @return

* @throws IOException

*/

public static String exportWord(String templateFolder, String ftlFile, Map map, String localPath, String title) throws IOException {

Configuration configuration = new Configuration();

configuration.setDefaultEncoding("utf-8");

configuration.setClassicCompatible(true);

configuration.setDirectoryForTemplateLoading(new File(templateFolder)); //读取ftl 模板位置

try {

String datePath = DateUtils.getNowTime("yyyy/MM/dd");

//使用时间为文件夹生成word生成的位置

String path = localPath + "/word/" + datePath;

//定义word文档名称

String fileName = title + ".doc";

//创建文件夹

File outFile = new File(path + "/" + fileName);

if (!outFile.getParentFile().exists()) {

outFile.getParentFile().mkdirs();

}

//读取 模板内容

Template template = configuration.getTemplate(ftlFile, "utf-8");

Writer out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile), "UTF-8"));

template.process(map, out);

out.flush();

out.close();

return path + "/" + fileName;

} catch (TemplateException e) {

e.printStackTrace();

}

return "";

}

}

自此,你的doc文件实际上已经生成在你指定的文件夹了。 接下来如果让他能够使用文浏览器下载,只需要去读取你本地的这个文件就行。`

@SuppressWarnings("unchecked")

@RequestMapping(value = "/word/download/{id}")

public void exportSupplier(@PathVariable("id") Integer gysbaId, HttpServletResponse response, HttpServletRequest request) {

try {

// 注意这里的参数,根据你自己业务出入,参数说明上面已经注明!

String downLoadPath = WordUtils.exportWord(templateFolder,ftlName,map,root,title);

String fileName = map.get("message").toString();

File file = new File(downLoadPath);

InputStream inputStream;

inputStream = new BufferedInputStream(new FileInputStream(file));

byte[] buffer = new byte[inputStream.available()];

inputStream.read(buffer);

inputStream.close();

response.reset();

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");

}

response.setHeader("Content-disposition", String.format("attachment; filename=\"%s\"", fileName));

response.addHeader("Content-Length", "" + file.length());

response.setContentType("application/x-download");

os.write(buffer);// 输出文件

os.flush();

os.close();

} catch (Exception e) {

e.printStackTrace();

}

}

好的,大功告成!如果发现有什么问题,希望各位大佬指出,共同学习。

love & peace

java word 分页显示_java使用freemaker 导出word 包含分页,表格循环,word改xml格式化...相关推荐

  1. android listview分页显示,Android应用中使用ListView来分页显示刷新的内容

    点击按钮刷新1.效果如下: 实例如下:  上图的添加数据按钮可以换成一个进度条  因为没有数据所以我加了一个按钮添加到数据库用于测试:一般在服务器拉去数据需要一定的时间,所以可以弄个进度条来提示用户: ...

  2. java调用word模板文件_Java使用模板导出word文档

    Java使用模板导出word文档 需要导入freemark的jar包 使用word模板,在需要填值的地方使用字符串代替,是因为word转换为xml文件时查找不到要填入内容的位置.尽量不要在写字符串的时 ...

  3. java循环导出word文档_Java使用freemarker导出word文档

    通过freemarker,以及JAVA,导出word文档. 共分为三步: 第一步:创建模板文件 第二步:通过JAVA创建返回值. 第三步:执行 分别介绍如下: 第一步: 首先创建word文档,按照想要 ...

  4. java jpanel 分层显示_java – 向JPanel显示视频

    我正在创建一个简单的视频播放器,但我有问题显示要在JPanel中流式传输的视频文件.我创建并设计了一个JFrame,并在表单中放置了一个方形大小的JPanel. 到目前为止,这是我的代码: packa ...

  5. java 图形立即显示_java 图形显示

    importjavax.swing.*;importjava.awt.*;importjava.awt.Event.*;//从文本框中输入一个值.按回车键弹出对话框显示该输入值.publicclass ...

  6. java jpopupmenu 无法显示_JAVA :为什么使用Jpopupmenu()有参构造方法 不显示标题

    importjavax.swing.*;importjava.awt.*;importjava.awt.event.*;publicclassExample10_23{publicstaticvoid ...

  7. java打印字符串显示_JAVA调用系统打印机打印字符串

    用java实现打印,java.awt中提供了一些打印的API,要实现打印,首先要获得打印对象,然后继承Printable实现接口方法print,以便打印机进行打印,最后用用Graphics2D直接输出 ...

  8. java 串口 来电显示_java串口 来电显示

    二.用rxtx.jar代替comm.jar # copy rxtxSerial.dll into your c:\program files\java\jre-version\bin dir # co ...

  9. java 按钮不显示_JAVA图形界面,按钮为什么显示不出来?

    JAVA图形界面,按钮为什么显示不出来? 来源:互联网  宽屏版  评论 2009-10-22 02:51:03 分类: 电脑/网络 >> 软件 问题描述: import javax.sw ...

  10. java导出复杂excel表格_java使用freemarker导出复杂的excel表格

    正常导出excel表格使用的poi,但是导出复杂的excel有点困难,但是可以使用freemaker模板来导出复杂的excel. 都是先生成一个Excel表格的模板,最好是增加一行数据.具体看图里面的 ...

最新文章

  1. 京东Flink优化与技术实践
  2. python四大软件-9个使用Python的世界级软件公司
  3. 归并排序改良 java_Java 八种排序算法总结
  4. linux 监听数据包,linux下网络监听与发送数据包的方法(即libpcap、libnet两种类库的使用方法)...
  5. 【LeetCode】剑指 Offer 07. 重建二叉树
  6. .NET 内存管理与垃圾回收:实现IDisposable接口和析构函数
  7. ajax的总结和使用
  8. Python教程-python字典中key的灵活使用fromkeys()
  9. Label高度根据内容变化SnapKi
  10. jeesit的使用(一)
  11. Not have a lick 没有一丁点儿
  12. java word文档_[转载]java读写word文档,完美解决方案
  13. 敏捷团队的质量保障赋能
  14. Windows 10 使用命令行格式化磁盘/U盘
  15. Python + Selenium实现web端的UI自动化
  16. 二维蒙特卡洛模拟居里温度_蒙特卡罗方法计算居里温度(上)
  17. 液晶弹性自由能计算_液晶材料预倾角与弹性常量的关系
  18. RK3288 Android7.1 接USB摄像头后扬声器无声音
  19. C语言及程序设计 实践参考——个人所得税计算器if语句版
  20. Android Studio编译中出现No static method metafactory怎么办?_莫韵乐与bug的奇妙冒险

热门文章

  1. win7计算机 我的文档,我的文档在哪,详细教您win7“我的文档”在哪里
  2. ERP管理系统如何与精益生产MES有效结合
  3. viper4android资源分享,一步一步教你如何使4.42版本ROOT并且安装Viper4Android音效软件...
  4. 外贸独立站卖家如何借势营销?
  5. 123457123456#0#-----com.yuming.FromPuzzleGame01--前拼后广--宝宝农场拼图cym
  6. 手把手教你做项目多线程篇——基础知识详解
  7. 经验分享:如何快速上手公司的项目代码
  8. C# 打开和关闭软键盘
  9. vlookup匹配的文字显示0_Excel | VLOOKUP函数使用详解
  10. 我在上海对日外贸公司的经历