JAVA生成Word文档(经过测试)

摘要:
修改后,将文件的后缀直接更改为ftl。然后,直接编码:packagecom;importjava.io。BufferedWriter;importjava.io。文件importjava.io。FileNotFoundException;importjava.io。文件输出流;importjava.io。IOException;importjava.io。OutputStreamWriter;importjava.io。作家导入java.util。阵列列表;导入java.util。HashMap;导入java.util。列表导入java.util。地图importfreemark.template。配置importfreemark.template。样板importfreemark.template。TemplateException;publicclassWordTest{privateConfigurationconfiguration=null;publicWordTest(){configuration=newConfiguration();configuration.setDefaultEncoding;}publicstaticvoidmain{WordTesttest=newWordTest();test.createWord();}Publicvoid createWord(){MapdataMap=newHashMap<String,Object˃();getData;configuration.setClassForTemplateLoading;//FTL文件Template的位置=null;try{t=configuration.getTemplate;//文件名}catch{e.printStackTrace();}FileoutFile=newFile;Writerout=空;尝试{//out=newBufferedWriter;out=newOutputStreamWriter;//使用以上选项将导致由于编码问题而无法打开文档}catch{e1.printStackTrace();}尝试{t.process;}捕获{e.printStackTrace();}捕获{e.printStackTrace();}}privatevoidgetData{dataMap.put;dataMap.pput;dataMap.prut;dataMap.put;dataMap.put;dataMap.but;dataMap.put;//dataMap.pot;//dataMap.pput;List<Map<String,Object>>List=newArrayList<Map,Object>();对于{Map<String、Object>Map=newHashMap<String,Object>数据映射。put;}}您可能最关心的是遍历文件。freemarker的用法:http://www.havenliu.com/goodarticle/420.html直接编辑ftl文件:打开ftl文件,搜索˂w:tr,然后找到第一个。tr的含义无需解释。它代表一条线。

首先告诉大家这篇文章的原始出处:http://www.havenliu.com/java/514.html/comment-page-1#comment-756

我也是根据他所描述完成的,但是有一些地方有点模糊,不容易弄出来.所以,我另外写一篇,让大家少走一些弯路.

JAVA生成Word文档(经过测试)第1张

上图:是Word文档中的内容,也就是模板,为了下面步鄹做铺垫,所以在需要输入数据的地方改成了拼音,

将word文档另存为xml文件.

JAVA生成Word文档(经过测试)第2张

接下来,上面写的拼音就起到作用了.

打开xml文件.搜索 title.

将Title 改为 ${title}

其他地方一样的修改。

改完后,把文件的后缀名直接改成ftl。

然后呢,直接上代码:

package com;

import java.io.BufferedWriter;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.io.Writer;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

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

public class WordTest {
	
	private Configuration configuration = null;
	
	public WordTest(){
		configuration = new Configuration();
		configuration.setDefaultEncoding("UTF-8");
	}
	
	public static void main(String[] args) {
		WordTest test = new WordTest();
		test.createWord();
	}
	
	public void createWord(){
		Map<String,Object> dataMap=new HashMap<String,Object>();
		getData(dataMap);
		configuration.setClassForTemplateLoading(this.getClass(), "/com");  //FTL文件所存在的位置
		Template t=null;
		try {
			t = configuration.getTemplate("wordModel.ftl"); //文件名
		} catch (IOException e) {
			e.printStackTrace();
		}
		File outFile = new File("O:/outFilessa"+Math.random()*10000+".doc");
		Writer out = null;
		try {
//			out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile)));
              out = new OutputStreamWriter(new FileOutputStream(f), "utf-8");//使用上面的会因为编码问题造成文档无法打开 } catch (FileNotFoundException e1) { e1.printStackTrace(); } try { t.process(dataMap, out); } catch (TemplateException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } private void getData(Map<String, Object> dataMap) { dataMap.put("title", "标题"); dataMap.put("year", "2012"); dataMap.put("month", "2"); dataMap.put("day", "13"); dataMap.put("auditor", "唐鑫"); dataMap.put("phone", "13020265912"); dataMap.put("weave", "占文涛"); // dataMap.put("number", 1); // dataMap.put("content", "内容"+2); List<Map<String,Object>> list = new ArrayList<Map<String,Object>>(); for (int i = 0; i < 10; i++) { Map<String,Object> map = new HashMap<String,Object>(); map.put("number", i); map.put("content", "内容"+i); list.add(map); } dataMap.put("list", list); } }


大家现在可能最关心的是遍历的文件。接下来我们看如何遍历数据。

freemarker的用法:http://www.havenliu.com/goodarticle/420.html
 
在刚刚的那个ftl文件中直接编辑:
打开FTL文件,搜索   <w:tr
找到第一个,tr的意思不用解释了吧,代表着一行。
这也意味着我找到了Table中的第一行,但是我需要遍历的不是从第一行开始,而是从第二行。
好的,继续搜索,找到第二个。
 
JAVA生成Word文档(经过测试)第3张
 
在它的头上加一个<#list 你的集合名称 as xxxx>
ok,有开头就有结尾,玩过JSP上的EL表达式应该不会感觉很陌生吧。
搜索 </w:tr>
同样找到第二个,加上</#list>结束符。
好的,这样就没问题了。

免责声明:文章转载自《JAVA生成Word文档(经过测试)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Halcon学习之四:有关图像生成的函数Outlook 2016 自动发送/接收无法正常工作下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

XML和JSON数据格式

目录 XML DTD(文档类型定义) DTD实体 JSON 使用python解析JSON数据 XML和JSON的区别  XML的优缺点 JSON的优缺点 XML和JSON都是web存储和传输过程中数据的格式,其中JSON 使用比较广泛,主要用来前后端交互数据。 XML XML(Extensible Markup Language)扩展标记语言 ,是一种常...

C#读取带命名空间的xml,xaml文件的解决方案

使用C#读取xml文件有三种常用的方式: 1、xmlDocument 2、XmlTextReader 3、Linq To Xml 但是这些方式在读写有些带命名空间的xml时就不知道怎么办了(例如把xaml文件当作xml文件来读写的时候)。 对于xaml文件,C#虽然能用XamlReader直接把xaml文件转换为对象,但是有的时候我们只是想取得其中一些字段...

【持续集成】如何用sonar-pmd插件集成pmd-xml的规则

需求sonar-pmd插件只有添加了pmd的java规则,现在需要添加pmd的xml规则,更准确是添加自定义的xml规则. 步骤:为了更好集成和示范,选择前人已集成p3c的sonar-pmd插件.url: https://github.com/mrprince/sonar-p3c-pmdgit clone 到本地集成分为两个环节:1.规则配置2.源码修改...

基于docker创建的Jenkins,settings.xml文件放在哪里

如果运行容器时挂载目录如下 启动容器 docker run -itd -p 8080:8080 -p 50000:50000 --name jenkins --privileged=true  --restart=always -v /home/jenkins_home:/var/jenkins_home jenkins/jenkins:latest 则需...

使用C#读写结构化的二进制文件

最近工作上遇到一个问题,就是有将近200万个CSV文件,每个CSV文件包含了成千上万条实验数据,CSV以一个不连续的整数值作为文件名,比如:1.CSV、2.CSV、3.CSV、5.CSV等等。另外又有200万个XML文件,每个XML文件的文件名与CSV的文件名一一对应,在这些XML文件中,定义了所对应的CSV实验数据文件的实验描述信息(比如实验名称、实验类...

[软件过程/软件生命周期模型]软件过程的工具链【待续】

0 宣言:DevOps & RUP统一过程建模 1 项目管理 (需求管理 / 缺陷管理 / ...) 禅道(前身:bugfree) [在线协作] JIRA(项目与事务跟踪工具) 与禅道类同,但又不同,有明显的Scrum敏捷风格 Microsoft Project [离线维护] 在线文档 or Excel 2 系统建模 2....