jacob使用入门及问题解析
转自:http://blog.csdn.net/hemingwang0902/article/details/4377994
本博客 jacob 列文章导读
Java操作Microsoft Word之jacob
jacob使用入门及问题解析
使用Jacob将Word转为Html或txt
使用Jacob将Word转为PDF
java通过jacob调用word (根据Word模板生成动态内容)
首先,大家先要了解一下jacob ,官方的解释是Java COM Bridge,即java和com组件间的桥梁(进一步了解com/dcom: http://docs.huihoo.com/com/)
com一般表现为dll或exe等二进制文件,像我们呆会会用到的jacob.dll文件,这里说说为什么我们用java去操纵office(如:word)要使用com,而不直接使用java去做?
首先,我们清楚office是建立在windows平台之上的,本身是一个软件,除了他自己提供的宏似乎没有什么能对他进行直接的操作;在windows平台上为了解决像这样的不同应用软件,通信缺乏通用api问题,推出了com的解决方案;
其次,我们使用dll中的一组或多组相关的函数存取组件数据,总的合称为接口具体到每个细节的实现称为方法;如果我们要调用接口里的方法,唯一的途径就是调用指向接口的指针;
所以总的来说使用就是dll完成api的转换;
不懂没关系,会用就好,用久自然懂了, 好了com讲完,我们开始我们的主要内容吧!
大家先到这里下载jacob.jar
里面的jacob.jar是我们要用的包
jacob.dll就是我前面说的com组件
把包里的jacob.dll放到c:/windows/system32下
讲解麻烦,画个图大家看 好
值得注意的是,不同的版本的系统使用不同的dll文件
所以如果你编译成功,但运行失败一般是dll文件问题
遇到这种情况,可以到
http://downloads.sourceforge.net/jacob-project/jacob_1.9.zip?modtime=1109437002&big_mirror=0
下载其他的版本的 dll 文件。
先给大家个word的测试代码(经过更改该代码在我的机器上运行正常)
- import com.jacob.activeX.ActiveXComponent;
- import com.jacob.com.ComException;
- import com.jacob.com.Dispatch;
- import com.jacob.com.Variant;
- public class WordDocumentProperties {
- /** 声明一个word对象*/
- private ActiveXComponent objWord;
- /** 声明四个word组件*/
- private Dispatch custDocprops;
- private Dispatch builtInDocProps;
- private Dispatch document;
- private Dispatch wordObject;
- public WordDocumentProperties() {
- }
- /**
- * 打开word文挡
- */
- public void open(String filename) {
- // 创建一个word对象
- objWord = new ActiveXComponent("Word.Application");
- // 为wordobject组件附值
- wordObject = (Dispatch) (objWord.getObject()); // 改了这里
- // 生成一个只读方式的word文挡组件
- Dispatch.put(wordObject, "Visible", new Variant(false));
- // 获取文挡属性
- Dispatch documents = objWord.getProperty("Documents").toDispatch();
- // 打开激活文挡
- document = Dispatch.call(documents, "Open", filename).toDispatch();
- }
- public void selectCustomDocumentProperitiesMode() {
- custDocprops = Dispatch.get(document, "CustomDocumentProperties").toDispatch();
- }
- public void selectBuiltinPropertiesMode() {
- builtInDocProps = Dispatch.get(document, "BuiltInDocumentProperties").toDispatch();
- }
- /**
- * 关闭文挡
- */
- public void close() {
- Dispatch.call(document, "Close");
- }
- public String getCustomProperty(String cusPropName) {
- try {
- cusPropName = Dispatch.call((Dispatch) custDocprops, "Item", cusPropName).toString();
- } catch (ComException e) {
- cusPropName = null;
- }
- return cusPropName;
- }
- public String getBuiltInProperty(String builtInPropName) {
- try {
- builtInPropName = Dispatch.call((Dispatch) builtInDocProps, "Item", builtInPropName).toString();
- } catch (ComException e) {
- builtInPropName = null;
- }
- return builtInPropName;
- }
- public static void main(String[] args) {
- try {
- WordDocumentProperties jacTest = new WordDocumentProperties();
- jacTest.open("s.doc");
- jacTest.selectCustomDocumentProperitiesMode();
- jacTest.selectBuiltinPropertiesMode();
- String custValue = jacTest.getCustomProperty("Information Source");
- String builtInValue = jacTest.getBuiltInProperty("Author");
- jacTest.close();
- System.out.println(" Document Val One: " + custValue);
- System.out.println(" Document Author: " + builtInValue);
- } catch (Exception e) {
- System.out.println(e);
- }
- }
- }
jacob使用入门及问题解析的更多相关文章
- Android入门(二十一)解析XML
原文链接:http://www.orlion.ga/685/ 解析XML常用的方式有两种,一种是PULL解析一种是SAX解析. 假设解析数据为: <apps> <app> ...
- EasyUI基础入门之Parser(解析器)
前言 JQuery EasyUI提供的组件包含功能强大的DataGrid,TreeGrid.面板.下拉组合等.用户能够组合使用这些组件,也能够单独使用当中一个.(使用的形式是以插件的方式提供的) Ea ...
- javaweb入门20160305---xml的解析入门
一个XML文件除了我们人去读写以外,我们希望可以通过程序去读写,利用程序去增删改查XML的过程就是XML编程 CRUD:Create.Read.Update.Delete XML的两种解析方式 d ...
- dump解析入门-用VS解析dump文件进行排障
突然有一天部署在服务器的一个应用挂掉了,没办法只能进入服务器打开 [事件查看器]查看下,好不容易找到了打开后一脸懵逼 事件查看器查到的内容根本对我们排障没有任何作用. 在这个时候如果有对应的dump文 ...
- ECMAScript6 入门 变量的解析赋值
ES6 允许按照一定模式,先=从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring). 这句话的解释:第一步从数组或者对象中提取值,第二步将提取到的值对变量进行赋值 数组的解 ...
- UE4官方行为树快速入门文档解析和修改
近学习了UE4官方文档的行为树快速入门指南,发现里面的部分逻辑稍稍有点混乱和重叠,于是加入了自己的想法,修改了部分行为树逻辑,优化了其AI寻路能力. 初始的基本操作和资源创建同官方文档一样:1个Fol ...
- js模块化入门与commonjs解析与应用
JS模块化的基本原理 commonjs规范 commonjs在前端模块化中的基本使用 AMD与CMD规范剖析博客链接 一.JS模块化基本原理 在JS没有提出来模块化的时候,开发JS项目比较简单,同时也 ...
- 【SpringMVC架构】SpringMVC入门实例,解析工作原理(二)
上篇博文,我们简单的介绍了什么是SpringMVC.这篇博文.我们搭建一个简单SpringMVC的环境,使用非注解形式实现一个HelloWorld实例,从简单入手,逐步深入. 环境准备 我们须要有主要 ...
- centos7安装nginx-1.13.6 新手入门,图文解析
系统环境 操作系统:64位CentOS Linux release 7.2.1511 (Core) 安装nginx依赖包 [root@localhost ~]# yum install gcc-c++ ...
随机推荐
- hive的窗口函数ntile、row_number、rank
一.ntile 序列函数不支持window子句 数据准备: cookie1,--, cookie1,--, cookie1,--, cookie1,--, cookie1,--, cookie1,-- ...
- IEEEXtreme 10.0 - Dog Walking
博客中的文章均为 meelo 原创,请务必以链接形式注明 本文地址 Xtreme 10.0 - Dog Walking 题目来源 第10届IEEE极限编程大赛 https://www.hackerra ...
- day1 python简介和入门
Linux的yum依赖自带Python,为防止错误,此处更新其实就是再安装一个Python: 安装Python 1.下载安装包 https://www.python.org/downloads ...
- python开发学习-day02(元组、字符串、列表、字典深入)
s12-20160109-day02 *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: ...
- pyqt5之QColorDialog颜色对话框最简单使用
设置窗体背景颜色 QWidget.setStyleSheet('QWidget {background-color:#88ab45}') 颜色对话框取得颜色值是十六进制. col=QCo ...
- ubuntu 系统提示升级失败,boot空间不足
系统提示升级失败,boot空间不足,解决方法: linux 随着系统的升级,会自动攒下好几个内核 执行 uname -a 看下自己当前启动的是哪个内核 dpkg --get-selections |g ...
- vue-router history 模式 iis 配置
首先需要安装 url rewrite模块到IIS点我安装 然后在web.config文件中添加如下配置 <?xml version="1.0" encoding=" ...
- ftp缓存信息
using System.Collections.Generic; using NewTempo.Ftp; using System.IO; using NshowAdClient.NshowAdSe ...
- vue-music 关于搜索历史本地存储
搜索历史 搜索过的关键词 保存在本地存储 localstorage 中,同时多个组件共享搜索历史数据,将数据存到vuex 中,初始值从本地缓存中取得对应key 的值,没有数据默认为空数组 点击搜索关键 ...
- 长安大学第四届ACM-ICPC“迎新杯”程序设计竞赛-重现赛 H - 圣诞节糖果
题目描述 圣诞节临近,彩虹岛的黑心商人