java txt 转word

合集下载

用Java读取Word文档

用Java读取Word文档

用Java读取Word文档由于Word的编码方式比较复杂,所以Word文档不可能通过流的方式直接读取;当然如果Word可以转化成TXT文件就可以直接读取了;目前读取Word比较好的开源工具是Poi及Jacob,感觉Poi读取功能要比Jacob略逊一筹,毕竟Jacob可以直接调用Word的COM组件;但是微软产品不开放源码,所以Jacob读取Word文档也只能是摸着石头过河,一点一点破解了。

Jacob读取Word内容,由于Word内容的复杂性,读取也是非常不方便的,目前可以有"按段落读取","按书签读取"及"按照表格读取"等几种形式。

示例讲解(通过Java FileReader,Jacob两种方式读取Word内容)一.通过java流读取Word内容复制代码1.import java.io.BufferedReader;2.import java.io.FileReader;3.import java.io.IOException;4.5.public class ReadWordByStream {6.public static void main(String[] args) throws IOException {7. String rowContent = new String();8. String content = new String();9. BufferedReader in = new BufferedReader(new FileReader("d:\\test3.doc"));10. while ((rowContent = in.readLine()) != null) {11.content = content + rowContent + "\n";12. }13. System.out.println(content.getBytes());14. System.out.println(new String(content.getBytes(),"utf-8"));//因为编码方式不同,不容易解析15. in.close();16.}17.18.}二.通过Jacob读取Word内容复制代码1.import com.jacob.activeX.ActiveXComponent;2.import Thread;3.import .Dispatch;4.import .Variant;5.6.public class WordReader {7.public static void main(String args[]) {8. ComThread.InitSTA();// 初始化com的线程9. ActiveXComponent wordApp = new ActiveXComponent("Word.Application"); // 启动word10. // Set the visible property as required.11. Dispatch.put(wordApp, "Visible", new Variant(true));// //设置word可见12. Dispatch docs = wordApp.getProperty("Documents").toDispatch();//所有文档窗口13.// String inFile = "d:\\test.doc";14.// Dispatch doc = Dispatch.invoke(docs,"Open",Dispatch.Method,15.// new Object[] { inFile, new Variant(false),new Variant(false) },//参数3,false:可写,true:只读16.// new int[1]).toDispatch();//打开文档17.18. Dispatch doc = Dispatch.call(docs, "Add").toDispatch(); //创建一个新文档19. Dispatch wordContent = Dispatch.get(doc, "Content").toDispatch(); //取得word文件的内容20. Dispatch font = Dispatch.get(wordContent, "Font").toDispatch();21. Dispatch.put(font, "Bold", new Variant(true)); // 设置为粗体22.Dispatch.put(font, "Italic", new Variant(true)); // 设置为斜体23.Dispatch.put(font, "Underline", new Variant(true));24.Dispatch.put(font, "Name", new Variant("宋体"));25.Dispatch.put(font, "Size", new Variant(14));26. for(int i=0;i<10;i++){//作为一个段落27.Dispatch.call(wordContent, "InsertAfter", "current paragraph"+i+" ");28. }29. for(int j=0;j<10;j++){//作为十个段落30. Dispatch.call(wordContent, "InsertAfter", "current paragraph"+j+"\r");31.}32. Dispatch paragraphs = Dispatch.get(wordContent, "Paragraphs")33. .toDispatch(); //所有段落34. int paragraphCount = Dispatch.get(paragraphs, "Count").getInt();35. System.out.println("paragraphCount:"+paragraphCount);36.37. for (int i = 1; i <= paragraphCount; i++) {38.Dispatch paragraph = Dispatch.call(paragraphs, "Item",39.new Variant(i)).toDispatch();40.Dispatch paragraphRange = Dispatch.get(paragraph, "Range")41..toDispatch();42.String paragraphContent = Dispatch.get(paragraphRange, "Text")43..toString();44.System.out.println(paragraphContent);45.//Dispatch.call(selection, "MoveDown");46. }47. // WordReader.class.getClass().getResource("/").getPath().substring+"test.doc";48. Dispatch.call(doc, "SaveAs","d:\\wordreader.doc");49. // Close the document without saving changes50. // 0 = wdDoNotSaveChanges51. // -1 = wdSaveChanges52. // -2 = wdPromptToSaveChanges53. ComThread.Release();//释放com线程54. Dispatch.call(docs, "Close", new Variant(0));55. docs = null;56. Dispatch.call(wordApp,"Quit");57. wordApp = null;58.}59.}用Java简单的读取word文档中的数据:第一步:下载tm-extractors-0.4.jar下载地址:/browser/elated-core/trunk/lib/tm-extractors-0.4.jar?rev =46并把它放到你的classpath路径下面。

javaPOIHTML转Word两种方式

javaPOIHTML转Word两种方式

javaPOIHTML转Word两种⽅式说明,不论使⽤哪种⽅式,都不能引⽤CSS来渲染样式,⽽是使⽤style,或者将样式放在当前页⾯的<style></style>中⽅法⼀、1、引⽤的jar包<dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>4.1.0</version></dependency>2、核⼼代码String html = "<div>测试内容</div";POIFSFileSystem poifs = null;FileOutputStream ostream = null;ByteArrayInputStream bais = null;String uuid = "测试.doc";File file = null;try { //HTML内容必须被<html><body></body></html>包装 fileParam.setcContent("<html><body>" + html + "</body></html>"); byte[] b = fileParam.getcContent().getBytes(); bais = new ByteArrayInputStream(b); poifs = new POIFSFileSystem(); DirectoryEntry directory = poifs.getRoot(); //WordDocument名称不允许修改 directory.createDocument("WordDocument", bais); ostream = new FileOutputStream(uuid); poifs.writeFilesystem(ostream);//当前⽬录下就⽣成了⼀个测试.doc的⽂档} catch (Exception e) { logger.error("exception is {}", e);} finally { IOUtils.closeQuietly(poifs); IOUtils.closeQuietly(ostream); IOUtils.closeQuietly(bais); try { FileUtils.forceDelete(file); } catch (Exception e2) { }}⽅法⼆/*** word格式html的标签头*/public static final String HTML_TAG_BGN = "<html xmlns=\"/TR/REC-html40\" xmlns:v=\"urn:schemas-microsoft-com:vml\" xmlns:o=\"urn:schemas-microsoft-com:office:office\" xmlns:w=\"urn:schemas-microsoft-com:office public filePath downloadWordReport(String htmlForPrint) {try {String wordString = htmlForPrint.replaceAll("<head>", "").replaceAll("<html>", HTML_TAG_BGN );String fileName = new String("测试⽂件.doc".getBytes(), "UTF-8");//上传⽂件⽅法return this.upload(new ByteArrayInputStream(wordString.getBytes()), fileName);} catch (Exception e) {return null;}}。

java实现pdf转word(文字)

java实现pdf转word(文字)

java实现pdf转word(⽂字)1:添加依赖<?xml version="1.0" encoding="UTF-8"?><project xmlns="/POM/4.0.0"xmlns:xsi="/2001/XMLSchema-instance"xsi:schemaLocation="/POM/4.0.0 /xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>pdfToWord</groupId><artifactId>pdfToWord</artifactId><version>1.0-SNAPSHOT</version><dependencies><dependency><groupId>commons-logging</groupId><artifactId>commons-logging</artifactId><version>1.2</version></dependency><dependency><groupId>org.apache.pdfbox</groupId><artifactId>fontbox</artifactId><version>2.0.11</version></dependency><dependency><groupId>com.levigo.jbig2</groupId><artifactId>levigo-jbig2-imageio</artifactId><version>2.0</version></dependency><dependency><groupId>org.apache.pdfbox</groupId><artifactId>pdfbox-tools</artifactId><version>2.0.11</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId><version>2.6</version></dependency></dependencies></project>2:编写转换的⽅法import org.apache.pdfbox.pdmodel.PDDocument;import org.apache.pdfbox.text.PDFTextStripper;import java.io.*;/*** 把pdf转换为word格式** @author Angin* @date 2019/3/18 0018.*/public class PdfToWord {/*** 转换*/public void convertText(String pdfPath) {PDDocument doc = null;OutputStream fos = null;Writer writer = null;PDFTextStripper stripper = null;try {doc = PDDocument.load(new File(pdfPath));fos = new FileOutputStream(pdfPath.substring(0, pdfPath.indexOf(".")) + ".doc");writer = new OutputStreamWriter(fos, "UTF-8");stripper = new PDFTextStripper();int pageNumber = doc.getNumberOfPages();stripper.setSortByPosition(true);stripper.setStartPage(1);stripper.setEndPage(pageNumber);stripper.writeText(doc, writer);writer.close();doc.close();} catch (IOException e) {e.printStackTrace();}System.out.println("end..");}}3:main⽅法中进⾏测试/*** main⽅法测试* @author Angin* @date 2019/3/18 0018.*/public class MainClass {public static void main(String[] args) {PdfToWord convert=new PdfToWord();convert.convertText("E:\\pdfToWord.pdf");}}此⽅法只适合⽂档型的pdf转换,如果图⽚的话,转换后⽆法读取。

java根据模板生成word文档,兼容富文本、图片

java根据模板生成word文档,兼容富文本、图片

java根据模板⽣成word⽂档,兼容富⽂本、图⽚Java⾃动⽣成带图⽚、富⽂本、表格等的word⽂档使⽤技术 freemark+jsoup ⽣成mht格式的伪word⽂档,已经应⽤项⽬中,确实是可⾏的,⽆论是富⽂本中是图⽚还是表格,都能在word中展现出来使⽤jsoup解析富⽂本框,将其中的图⽚进⾏Base64位转码,使⽤freemark替换模板的占位符,将变量以及图⽚资源放⼊模板中在输出⽂件maven地址<!--freemarker--><!--<dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.23</version></dependency><!--JavaHTMLParser--><!--<dependency> <groupId>org.jsoup</groupId> <artifactId>jsoup</artifactId> <version>1.10.2</version></dependency>制作word的freemark模板1. 先将wrod的格式内容定义好,如果需要插⼊参数的地⽅以${xxx}为表⽰,例:${product}模板例⼦: 2. 将模板另存为mht格式的⽂件,打开该⽂件检查每个变量(${product})是否完整,有可能在${}中出现其他代码,需要删除。

3. 将mht⽂件变更⽂件类型,改成ftl为结尾的⽂件,引⼊到项⽬中 4. 修改ftl模板⽂件,在⽂件中加上图⽚资源占位符${imagesBase64String},${imagesXmlHrefString}具体位置如下图所⽰: 5. ftl⽂件中由⼏个关键配置需要引⼊到代码中:docSrcParent = word.filesdocSrcLocationPrex =nextPartId = 01D2C8DD.BC13AF60上⾯三个参数,在模板⽂件中可以找到,需要进⾏配置,如果配置错误,图⽚⽂件将不会显⽰下⾯这三个参数固定,切换模板也不会改变shapeidPrex = _x56fe__x7247__x0020typeid = #_x0000_t75spidPrex = _x0000_i 6. 模板引⼊之后进⾏代码编辑源码地址为:下载源码后需要进⾏调整下内容:1. 录⼊步骤5中的6个参数2. 修改freemark获取模板⽅式下⾯这种⽅式能获取模板,但是在项⽬打包之后⽆法获取jar包内的⽂件Configuration configuration=newConfiguration(Configuration.getVersion());configuration.setDefaultEncoding(StandardCharsets.UTF_8.toString());configuration.setDirectoryForTemplateLoading(newFile(templatePath));Template template=configuration.getTemplate("xxx.ftl");通过流的形式直接创建模板对象Configuration configuration=newConfiguration(Configuration.getVersion());configuration.setDefaultEncoding(StandardCharsets.UTF_8.toString());configuration.setDirectoryForTemplateLoading(newFile(templatePath));InputStream inputStream=newFileInputStream(newFile(templatePath+"/"+templateName)); InputStreamReader inputStreamReader=newInputStreamReader(inputStream,StandardCharsets.UTF_8); Template template=newTemplate(templateName,inputStreamReader,configuration);。

Java实现word文档在线预览,读取office(word,excel,ppt)文件

Java实现word文档在线预览,读取office(word,excel,ppt)文件

Java实现word⽂档在线预览,读取office(word,excel,ppt)⽂件想要实现word或者其他office⽂件的在线预览,⼤部分都是⽤的两种⽅式,⼀种是使⽤openoffice转换之后再通过其他插件预览,还有⼀种⽅式就是通过POI读取内容然后预览。

⼀、使⽤openoffice⽅式实现word预览主要思路是:1.通过第三⽅⼯具openoffice,将word、excel、ppt、txt等⽂件转换为pdf⽂件2.通过swfTools将pdf⽂件转换成swf格式的⽂件3.通过FlexPaper⽂档组件在页⾯上进⾏展⽰我使⽤的⼯具版本:openof:3.4.1swfTools:1007FlexPaper:这个关系不⼤,我随便下的⼀个。

推荐使⽤1.5.1JODConverter:需要jar包,如果是maven管理直接引⽤就可以操作步骤:1.office准备下载openoffice:从过往⽂件,其他语⾔中找到中⽂版3.4.1的版本下载后,解压缩,安装然后找到安装⽬录下的program ⽂件夹在⽬录下运⾏soffice -headless -accept="socket,host=127.0.0.1,port=8100;urp;" -nofirststartwizard如果运⾏失败,可能会有提⽰,那就加上 .\ 在运⾏试⼀下这样openoffice的服务就开启了。

2.将flexpaper⽂件中的js⽂件夹(包含了flexpaper_flash_debug.js,flexpaper_flash.js,jquery.js,这三个js⽂件主要是预览swf⽂件的插件)拷贝⾄⽹站根⽬录;将FlexPaperViewer.swf拷贝⾄⽹站根⽬录下(该⽂件主要是⽤在⽹页中播放swf⽂件的播放器)项⽬结构:页⾯代码:fileUpload.jsp<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>⽂档在线预览系统</title><style>body {margin-top:100px;background:#fff;font-family: Verdana, Tahoma;}a {color:#CE4614;}#msg-box {color: #CE4614; font-size:0.9em;text-align:center;}#msg-box .logo {border-bottom:5px solid #ECE5D9;margin-bottom:20px;padding-bottom:10px;}#msg-box .title {font-size:1.4em;font-weight:bold;margin:0 0 30px 0;}#msg-box .nav {margin-top:20px;}</style></head><body><div id="msg-box"><form name="form1" method="post" enctype="multipart/form-data" action="docUploadConvertAction.jsp"><div class="title">请上传要处理的⽂件,过程可能需要⼏分钟,请稍候⽚刻。

Java实现上传txt,doc,docx文件并且读取内容

Java实现上传txt,doc,docx文件并且读取内容

Java实现上传txt,doc,docx⽂件并且读取内容1,前端上传/导⼊⽂件:var uploaderXls = new plupload.Uploader({//创建实例的构造⽅法runtimes: 'gears,html5,html4,silverlight,flash', //上传插件初始化选⽤那种⽅式的优先级顺序browse_button: 'btnImportXls', // 上传按钮url: "resumeController.do?importExcel", //远程上传地址flash_swf_url: 'plug-in/plupload/js/Moxie.swf', //flash⽂件地址silverlight_xap_url: 'plug-in/plupload/js/Moxie.xap', //silverlight⽂件地址filters: {max_file_size: '10mb', //最⼤上传⽂件⼤⼩(格式100b, 10kb, 10mb, 1gb)mime_types: [//允许⽂件上传类型{title: "files", extensions: "txt,doc,docx"}]},multipart_params:{isup:"1"},multi_selection: false, //true:ctrl多⽂件上传, false 单⽂件上传init: {FilesAdded: function(up, files) { //⽂件上传前debugger;uploaderXls.start();},FileUploaded: function(up, file, info) { //⽂件上传成功的时候触发info1 = JSON.parse(info.response);$("#resumeList").datagrid();layer.alert(info1.msg);//console.log(info.message);},Error: function(up,info, err) { //上传出错的时候触发layer.alert(err.message);}}});uploaderXls.init();2,后台接收⽂件,并读取:MultipartFile是spring的⼀个接⼝,通常我们可以在controller定义⽅法使⽤MultipartFile接收form表单提交的⽂件,然后将MultipartFile可以转化成⼀个⽂件。

java 注解数字转换成文字的方法

java 注解数字转换成文字的方法

java 注解数字转换成文字的方法【原创实用版4篇】目录(篇1)I.Java注解概述A.注解定义及作用B.Java注解发展历程II.数字转换成文字的方法A.使用Java内置方法B.使用第三方库C.自定义注解实现正文(篇1)Java注解是一种在Java程序中添加元数据的方法,用于在编译时或运行时对代码进行标记和处理。

Java注解的发展历程可以追溯到Java 1.5版本,自那时以来,注解已经成为Java编程语言的一个重要组成部分。

A.使用Java内置方法在Java中,可以使用内置的NumberFormat类将数字转换成文字。

NumberFormat类提供了许多静态方法,可以将数字转换成不同格式的字符串,例如货币、百分比、科学计数法等。

例如,以下代码将一个整数转换成货币格式的字符串:```javaimport java.text.NumberFormat;public class NumberToText {public static void main(String[] args) {int number = 12345;NumberFormat formatter =NumberFormat.getInstance(); // 使用美国本地化设置 String text = formatter.format(number);System.out.println(text); // 输出:$12,345}}```B.使用第三方库除了Java内置的方法之外,还可以使用第三方库将数字转换成文字。

其中最常用的是Apache Commons Lang库中的MessageFormat类。

MessageFormat类提供了一种格式化字符串的方式,可以插入变量和表达式,并将它们转换成指定的格式。

例如,以下代码将一个整数转换成带有占位符的字符串:```javaimport ng3.text.WordUtils;import java.text.MessageFormat;import java.util.Locale;public class NumberToText {public static void main(String[] args) {int number = 12345;String pattern = "{0,number,currency}{0,number,percent}"; // 货币和百分比的格式化字符串Locale locale = ; // 使用美国本地化设置MessageFormat formatter = new MessageFormat(pattern, locale);String text = formatter.format(new Object[]{number}); // 格式化字符串并插入变量numberSystem.out.println(text); // 输出:$12,345 100%}}```C.自定义注解实现除了使用内置方法和使用第三方库之外,还可以自定义注解来实现数字转换成文字的功能。

java将html转为word导出(富文本内容导出word)

java将html转为word导出(富文本内容导出word)

java将html转为word导出(富⽂本内容导出word)业务:将富⽂本内容取出⽣成本地word⽂件参考百度的⽅法word本⾝是可以识别html标签,所以通过poi写⼊html内容即可import com.util.WordUtil;import org.springframework.web.bind.annotation.PostMapping;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;public class SysAnnouncementController {@PostMapping(value = "/exportAccidentExampleWord")public void exportAccidentExampleWord(HttpServletRequest request, HttpServletResponse response) throws Exception {String s = "<p><strong>第⼀⾏要加粗</strong></p>\n" +"<p><em><strong>第⼆⾏要倾斜</strong></em></p>\n" +"<p style=\"text-align: center;\"><em><strong>第三⾏要居中</strong></em></p>";StringBuffer sbf = new StringBuffer();sbf.append("<html " +"xmlns:v=\"urn:schemas-microsoft-com:vml\" xmlns:o=\"urn:schemas-microsoft-com:office:office\" xmlns:w=\"urn:schemas-microsoft-com:office:word\" xmlns:m=\"/office/2004/12/omml\" xmlns=\"http://w ">");//缺失的⾸标签sbf.append("<head>" +"<!--[if gte mso 9]><xml><w:WordDocument><w:View>Print</w:View><w:TrackMoves>false</w:TrackMoves><w:TrackFormatting/><w:ValidateAgainstSchemas/><w:SaveIfXMLInvalid>false</w:SaveIfXMLInvalid><w:IgnoreMixedCo "</head>");//将版式从web版式改成页⾯试图sbf.append("<body>");//缺失的⾸标签sbf.append(s);//富⽂本内容sbf.append("</body></html>");//缺失的尾标签try{WordUtil.exportWord(request,response,sbf.toString(),"wordName");}catch (Exception e){System.out.println(e.getMessage());}}}⼯具类import javax.servlet.ServletOutputStream;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import java.io.ByteArrayInputStream;import java.io.OutputStream;public class WordUtil {public static void exportWord(HttpServletRequest request, HttpServletResponse response, String content, String fileName) throws Exception {byte[] b = content.getBytes("GBK"); //这⾥是必须要设置编码的,不然导出中⽂就会乱码。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

使用JACOB进行Word编程示例2015年7月2日13:44Jacob项目的官方地址:/projects/jacob-project/官方介绍:JACOB is a JAVA-COM Bridge that allows you to call COM Automation components from Java. It uses JNI to make native calls to the COM libraries. JACOB runs on x86 and x64 environments supporting 32 bit and 64 bit JVMs它是一个使用jni来调用com组件及其库文件的工具。

这里仅介绍处理word文档。

首先要部署其dll文件。

jacob-1.14.3-x86.dll 或 jacob-1.14.3-x64.dll,下载的文件解压后即可看到。

我是直接将dll文件放在windows\system32目录下的,方便,当然也有其他做法。

其次,就是把其jar文件路径加入Windows路径中。

接着就可以在你的Java程序中调用了。

我总结下大概有下面几个阶段:1. 初始化相关参数,代码如下:// 打开Word应用程序ActiveXComponent app = new ActiveXComponent("Word.Application");// 设置word不可见app.setProperty("Visible", new Variant(false));// 打开word文件Dispatch word = app.getProperty("Documents").toDispatch();Dispatch doc = Dispatch.invoke(word, "Open", Dispatch.Method, new Object[] {" File Name", new Variant(false), new Variant(false) }, new int[1]).toDispatch();//获取指针Dispatch cursor = app.getProperty("Selection").toDispatch();如上,我们打开了一个名为File Name的word文件,你可能会觉得最后那句看起来很繁琐,是的,有更好的代替方式,如下:Dispatch doc = Dispatch.call(word, "Open", new Variant(false), new Variant(false) ).toDisptach();这正是Jacob给我们提供的两种调用方式。

2. 处理word文档,如果你先前有VBA相关开发经验,那就简单了。

没有的也没事,打开office程序目录下的2052\VBAWD10.chm,这里有Word的对象模型的所有记录。

接着讲述下Jacob中两种最常用的类型:Variant:这是一种可变的类型,用于Jacob中几乎所有函数的返回值,并可转换为其他任何类型,包括Java基本类型。

当然,应该按需要与规则来。

Dispatch:Object represents MS level dispatch object. Each instance of this points at some data structure on the MS windows side.就是说可以代表所有对象模型。

import java.util.ArrayList;import java.util.List;import com.jacob.activeX.ActiveXComponent;import Thread;import .Dispatch;import .Variant;import org.apache.log4j.Logger;/****作用:利用jacob插件生成word 文件!***/public class DOCWriter {/** 日志记录器 */static private Logger logger = Logger.getLogger(DOCWriter.class);/** word文档** 在本类中有两种方式可以进行文档的创建,<br>* 第一种调用 createNewDocument* 第二种调用 openDocument*/private Dispatch document = null;/** word运行程序对象 */private ActiveXComponent word = null;/** 所有word文档 */private Dispatch documents = null;/*** Selection 对象代表窗口或窗格中的当前所选内容。

所选内容代表文档中选定(或突出显示)的区域,如果文档中没有选定任何内容,则代表插入点。

* 每个文档窗格只能有一个Selection 对象,并且在整个应用程序中只能有一个活动的Selection 对象。

*/private Dispatch selection = null;/**** Range 对象代表文档中的一个连续区域。

每个 Range 对象由一个起始字符位置和一个终止字符位置定义。

* 说明:与书签在文档中的使用方法类似,Range 对象在 Visual Basic 过程中用来标识文档的特定部分。

* 但与书签不同的是,Range对象只在定义该对象的过程运行时才存在。

* Range对象独立于所选内容。

也就是说,您可以定义和处理一个范围而无需更改所选内容。

还可以在文档中定义多个范围,但每个窗格中只能有一个所选内容。

*/private Dispatch range = null;/*** PageSetup 对象该对象包含文档的所有页面设置属性(如左边距、下边距和纸张大小)。

*/private Dispatch pageSetup = null;/** 文档中的所有表格对象 */private Dispatch tables = null;/** 一个表格对象 */private Dispatch table = null;/** 表格所有行对象 */private Dispatch rows = null;/** 表格所有列对象 */private Dispatch cols = null;/** 表格指定行对象 */private Dispatch row = null;/** 表格指定列对象 */private Dispatch col = null;/** 表格中指定的单元格 */private Dispatch cell = null;/** 字体 */private Dispatch font = null;/** 对齐方式 */private Dispatch alignment = null;/*** 构造方法*/public DOCWriter() {if(this.word == null){/* 初始化应用所要用到的对象实例 */this.word = new ActiveXComponent("Word.Application");/* 设置Word文档是否可见,true-可见false-不可见 */this.word.setProperty("Visible",new Variant(true));/* 禁用宏 */this.word.setProperty("AutomationSecurity", new Variant(3)); }if(this.documents == null){this.documents = word.getProperty("Documents").toDispatch(); }}/*** 设置页面方向和页边距** @param orientation* 可取值0或1,分别代表横向和纵向* @param leftMargin* 左边距的值* @param rightMargin* 右边距的值* @param topMargin* 上边距的值* @param buttomMargin* 下边距的值*/public void setPageSetup(int orientation, int leftMargin,int rightMargin, int topMargin, int buttomMargin) {logger.debug("设置页面方向和页边距...");if(this.pageSetup == null){this.getPageSetup();}Dispatch.put(pageSetup, "Orientation", orientation);Dispatch.put(pageSetup, "LeftMargin", leftMargin);Dispatch.put(pageSetup, "RightMargin", rightMargin);Dispatch.put(pageSetup, "TopMargin", topMargin);Dispatch.put(pageSetup, "BottomMargin", buttomMargin);}/*** 打开文件** @param inputDoc* 要打开的文件,全路径* @return Dispatch* 打开的文件*/public Dispatch openDocument(String inputDoc) {logger.debug("打开Word文档...");this.document = Dispatch.call(documents,"Open",inputDoc).toDispatch();this.getSelection();this.getRange();this.getAlignment();this.getFont();this.getPageSetup();return this.document;}/*** 创建新的文件** @return Dispache 返回新建文件*/public Dispatch createNewDocument(){logger.debug("创建新的文件...");this.document = Dispatch.call(documents,"Add").toDispatch(); this.getSelection();this.getRange();this.getPageSetup();this.getAlignment();this.getFont();return this.document;}/*** 选定内容* @return Dispatch 选定的范围或插入点*/public Dispatch getSelection() {logger.debug("获取选定范围的插入点...");this.selection = word.getProperty("Selection").toDispatch();return this.selection;}/*** 获取当前Document内可以修改的部分<p><br>* 前提条件:选定内容必须存在** @param selectedContent 选定区域* @return 可修改的对象*/public Dispatch getRange() {logger.debug("获取当前Document内可以修改的部分...");this.range = Dispatch.get(this.selection, "Range").toDispatch();return this.range;}/*** 获得当前文档的文档页面属性*/public Dispatch getPageSetup() {logger.debug("获得当前文档的文档页面属性...");if(this.document == null){logger.warn("document对象为空...");return this.pageSetup;}this.pageSetup = Dispatch.get(this.document, "PageSetup").toDispatch(); return this.pageSetup;}/*** 把选定内容或插入点向上移动* @param count 移动的距离*/public void moveUp(int count) {logger.debug("把选定内容或插入点向上移动...");for(int i = 0;i < count;i++) {Dispatch.call(this.selection,"MoveUp");}/*** 把选定内容或插入点向下移动* @param count 移动的距离*/public void moveDown(int count) {logger.debug("把选定内容或插入点向下移动..."); for(int i = 0;i < count;i++) {Dispatch.call(this.selection,"MoveDown");}}/*** 把选定内容或插入点向左移动* @param count 移动的距离*/public void moveLeft(int count) {logger.debug("把选定内容或插入点向左移动..."); for(int i = 0;i < count;i++) {Dispatch.call(this.selection,"MoveLeft");}}/*** 把选定内容或插入点向右移动* @param count 移动的距离*/public void moveRight(int count) {logger.debug("把选定内容或插入点向右移动..."); for(int i = 0;i < count;i++) {Dispatch.call(this.selection,"MoveRight");}/*** 回车键*/public void enterDown(int count){logger.debug("按回车键...");for(int i = 0;i < count;i++) {Dispatch.call(this.selection, "TypeParagraph");}}/*** 把插入点移动到文件首位置*/public void moveStart() {logger.debug("把插入点移动到文件首位置...");Dispatch.call(this.selection,"HomeKey",new Variant(6));}/*** 从选定内容或插入点开始查找文本* @param selection 选定内容* @param toFindText 要查找的文本* @return boolean true-查找到并选中该文本,false-未查找到文本*/public boolean find(String toFindText) {logger.debug("从选定内容或插入点开始查找文本"+" 要查找内容: "+toFindText); /* 从selection所在位置开始查询 */Dispatch find = Dispatch.call(this.selection,"Find").toDispatch();/* 设置要查找的内容 */Dispatch.put(find,"Text",toFindText);/* 向前查找 */Dispatch.put(find,"Forward","True");/* 设置格式 */Dispatch.put(find,"Format","True");/* 大小写匹配 */Dispatch.put(find,"MatchCase","True");/* 全字匹配 */Dispatch.put(find,"MatchWholeWord","True");/* 查找并选中 */return Dispatch.call(find,"Execute").getBoolean();}/*** 把选定内容替换为设定文本* @param selection 选定内容* @param newText 替换为文本*/public void replace(String newText) {logger.debug("把选定内容替换为设定文本...");/* 设置替换文本 */Dispatch.put(this.selection,"Text",newText);}/*** 全局替换* @param selection 选定内容或起始插入点* @param oldText 要替换的文本* @param replaceObj 替换为文本*/public void replaceAll(String oldText,Object replaceObj) {logger.debug("全局替换...");/* 移动到文件开头 */moveStart();/* 表格替换方式 */String newText = (String) replaceObj;/* 图片替换方式 */if(oldText.indexOf("image") != -1 || stIndexOf(".bmp") != -1 ||stIndexOf(".jpg") != -1 || stIndexOf(".gif") != -1){while (find(oldText)) {insertImage(newText);Dispatch.call(this.selection,"MoveRight");}/* 正常替换方式 */} else {while (find(oldText)) {replace(newText);Dispatch.call(this.selection,"MoveRight");}}}/*** 插入图片* @param selection 图片的插入点* @param imagePath 图片文件(全路径)*/public void insertImage(String imagePath) {logger.debug("插入图片...");Dispatch.call(this.selection, "TypeParagraph");Dispatch.call(Dispatch.get(this.selection,"InLineShapes").toDispatch(),"AddPicture",i magePath);}/*** 合并表格** @param selection 操作对象* @param tableIndex 表格起始点* @param fstCellRowIdx 开始行* @param fstCellColIdx 开始列* @param secCellRowIdx 结束行* @param secCellColIdx 结束列*/public void mergeCell(int tableIndex, int fstCellRowIdx, int fstCellColIdx, int secCellRowIdx, int secCellColIdx){logger.debug("合并单元格...");if(this.table == null){logger.warn("table对象为空...");return;}Dispatch fstCell = Dispatch.call(table, "Cell",new Variant(fstCellRowIdx), new Variant(fstCellColIdx)).toDispatch();Dispatch secCell = Dispatch.call(table, "Cell",new Variant(secCellRowIdx), new Variant(secCellColIdx)).toDispatch();Dispatch.call(fstCell, "Merge", secCell);}/*** 想Table对象中插入数值<p>* 参数形式:ArrayList<String[]>List.size()为表格的总行数<br>* String[]的length属性值应该与所创建的表格列数相同** @param selection 插入点* @param tableIndex 表格起始点* @param list 数据内容*/public void insertToTable(List<String[]> list){System.out.println("向Table对象中插入数据...");logger.debug("向Table对象中插入数据...");if(list == null || list.size() <= 0){logger.warn("写出数据集为空...");return;}if(this.table == null){logger.warn("table对象为空...");return;}for(int i = 0; i < list.size(); i++){String[] strs = list.get(i);for(int j = 0; j<strs.length; j++){/* 遍历表格中每一个单元格,遍历次数与所要填入的内容数量相同 */ Dispatch cell = this.getCell(i+1, j+1);/* 选中此单元格 */Dispatch.call(cell, "Select");/* 写出内容到此单元格中 */Dispatch.put(this.selection, "Text", strs[j]);/* 移动游标到下一个位置 */}this.moveDown(1);}this.enterDown(1);}/*** 在文档中正常插入文字内容** @param selection 插入点* @param list 数据内容*/public void insertToDocument(List<String> list){logger.debug("向Document对象中插入数据...");if(list == null || list.size() <= 0){logger.warn("写出数据集为空...");return;}if(this.document == null){logger.warn("document对象为空...");return;}for(String str : list){/* 写出至word中 */this.applyListTemplate(3, 2);Dispatch.put(this.selection, "Text", str);this.moveDown(1);this.enterDown(1);}}/*** 创建新的表格** @param selection 插入点* @param document 文档对象* @param rowCount 行数* @param colCount 列数* @param width 边框数值 0浅色1深色* @return 新创建的表格对象*/public Dispatch createNewTable(int rowCount, int colCount, int width){logger.debug("创建新的表格...");if(this.tables == null){this.getTables();}this.getRange();if(rowCount > 0 && colCount > 0){this.table = Dispatch.call(this.tables,"Add",this.range,new Variant(rowCount),new Variant(colCount),new Variant(width)).toDispatch();}/* 返回新创建表格 */return this.table;}/*** 获取Document对象中的所有Table对象** @return 所有Table对象*/public Dispatch getTables(){logger.debug("获取所有表格对象...");if(this.document == null){logger.warn("document对象为空...");return this.tables;}this.tables = Dispatch.get(this.document, "Tables").toDispatch(); return this.tables;}/*** 获取Document中Table的数量** @return 表格数量*/public int getTablesCount(){logger.debug("获取文档中表格数量...");if(this.tables == null){this.getTables();}return Dispatch.get(tables, "Count").getInt();}/*** 获取指定序号的Table对象** @param tableIndex Table序列* @return*/public Dispatch getTable(int tableIndex){logger.debug("获取指定表格对象...");if(this.tables == null){this.getTables();}if(tableIndex >= 0){this.table = Dispatch.call(this.tables, "Item", new Variant(tableIndex)).toDispatch();}return this.table;}/*** 获取表格的总列数** @return 总列数*/public int getTableColumnsCount() {logger.debug("获取表格总行数...");if(this.table == null){logger.warn("table对象为空...");return 0;}return Dispatch.get(this.cols,"Count").getInt(); }/*** 获取表格的总行数** @return 总行数*/public int getTableRowsCount(){logger.debug("获取表格总行数...");if(this.table == null){logger.warn("table对象为空...");return 0;}return Dispatch.get(this.rows,"Count").getInt();}/*** 获取表格列对象** @return 列对象*/public Dispatch getTableColumns() {logger.debug("获取表格行对象...");if(this.table == null){logger.warn("table对象为空...");return this.cols;}this.cols = Dispatch.get(this.table,"Columns").toDispatch(); return this.cols;}/*** 获取表格的行对象** @return 总行数*/public Dispatch getTableRows(){logger.debug("获取表格总行数...");if(this.table == null){logger.warn("table对象为空...");return this.rows;}this.rows = Dispatch.get(this.table,"Rows").toDispatch();}/*** 获取指定表格列对象** @return 列对象*/public Dispatch getTableColumn(int columnIndex) {logger.debug("获取指定表格行对象...");if(this.cols == null){this.getTableColumns();}if(columnIndex >= 0){this.col = Dispatch.call(this.cols, "Item", newVariant(columnIndex)).toDispatch();}return this.col;}/*** 获取表格中指定的行对象** @param rowIndex 行序号* @return 行对象*/public Dispatch getTableRow(int rowIndex){logger.debug("获取指定表格总行数...");if(this.rows == null){this.getTableRows();}if(rowIndex >= 0){this.row = Dispatch.call(this.rows, "Item", new Variant(rowIndex)).toDispatch(); }}/*** 自动调整表格*/public void autoFitTable() {logger.debug("自动调整表格...");int count = this.getTablesCount();for (int i = 0; i < count; i++) {Dispatch table = Dispatch.call(tables, "Item", new Variant(i + 1)).toDispatch(); Dispatch cols = Dispatch.get(table, "Columns").toDispatch();Dispatch.call(cols, "AutoFit");}}/*** 获取当前文档中,表格中的指定单元格** @param CellRowIdx 单元格所在行* @param CellColIdx 单元格所在列* @return 指定单元格对象*/public Dispatch getCell(int cellRowIdx, int cellColIdx) {logger.debug("获取当前文档中,表格中的指定单元格...");if(this.table == null){logger.warn("table对象为空...");return this.cell;}if(cellRowIdx >= 0 && cellColIdx >=0){this.cell = Dispatch.call(this.table, "Cell", new Variant(cellRowIdx),newVariant(cellColIdx)).toDispatch();}}/*** 设置文档标题** @param title 标题内容*/public void setTitle(String title){logger.debug("设置文档标题...");if(title == null || "".equals(title)){logger.warn("文档标题为空...");return;}Dispatch.call(this.selection, "TypeText", title);}/*** 设置当前表格线的粗细** @param width* width范围:1<w<13,如果是0,就代表没有框*/public void setTableBorderWidth(int width) {logger.debug("设置当前表格线的粗细...");if(this.table == null){logger.warn("table对象为空...");return;}/** 设置表格线的粗细 1:代表最上边一条线 2:代表最左边一条线 3:最下边一条线4:最右边一条线 5:除最上边最下边之外的所有横线* 6:除最左边最右边之外的所有竖线 7:从左上角到右下角的斜线 8:从左下角到右上角的斜线*/Dispatch borders = Dispatch.get(table, "Borders").toDispatch();Dispatch border = null;for (int i = 1; i < 7; i++) {border = Dispatch.call(borders, "Item", new Variant(i)).toDispatch();if (width != 0) {Dispatch.put(border, "LineWidth", new Variant(width));Dispatch.put(border, "Visible", new Variant(true));} else if (width == 0) {Dispatch.put(border, "Visible", new Variant(false));}}}/*** 对当前selection设置项目符号和编号* @param tabIndex* 1: 项目编号* 2: 编号* 3: 多级编号* 4: 列表样式* @param index* 0:表示没有 ,其它数字代表的是该Tab页中的第几项内容*/public void applyListTemplate(int tabIndex,int index){logger.debug("对当前selection设置项目符号和编号...");/* 取得ListGalleries对象列表 */Dispatch listGalleries = Dispatch.get(this.word, "ListGalleries").toDispatch();/* 取得列表中一个对象 */Dispatch listGallery = Dispatch.call(listGalleries, "Item", newVariant(tabIndex)).toDispatch();Dispatch listTemplates = Dispatch.get(listGallery, "ListTemplates").toDispatch(); if(this.range == null){this.getRange();}Dispatch listFormat = Dispatch.get(this.range, "ListFormat").toDispatch();Dispatch.call(listFormat,"ApplyListTemplate",Dispatch.call(listTemplates, "Item", new Variant(index)), new Variant(true),new Variant(1),new Variant(0));}/*** 增加文档目录** 目前采用固定参数方式,以后可以动态进行调整*/public void addTablesOfContents(){/* 取得ActiveDocument、TablesOfContents、range对象 */Dispatch ActiveDocument = word.getProperty("ActiveDocument").toDispatch(); Dispatch TablesOfContents =Dispatch.get(ActiveDocument,"TablesOfContents").toDispatch();Dispatch range = Dispatch.get(this.selection, "Range").toDispatch();/* 增加目录 */Dispatch.call(TablesOfContents,"Add",range,new Variant(true),new Variant(1),new Variant(3),new Variant(true),new Variant(""),new Variant(true),new Variant(true));}/*** 设置当前Selection 位置方式* @param selectedContent 0-居左;1-居中;2-居右。

相关文档
最新文档