1 引言
在编程的时候,常常需要访问word文档。除了使用dde之外,powerbuilder还有一种操作word的方式,就是通过oleobjcet和olecontrol。
oleobject是不可视的ole对象,而olecontrol则是可视的窗口控件。由于oleobject较后者更灵活方便,如果不是必须在窗口上显示word文档内容,使用前者是更好的选择。
程序开发员在使用ole连接word文档的时候,常常遇到这样两个问题:
第一:如果某文档已经打开,再使用程序调用的时候,会产生程序运行错误;
第二:经常发现创建的winword.exe进程没有能够正常终止。
2 分析
下面我们来分析这两个错误产生的原因。
对于第一个错误,往往是由于使用oleobjectvar.connecttoobject(“<filename>”)的时候,<filename>这个文件已经打开了。此时使用connecttoobject会造成错误。
对于第二个错误,一般是使用 oleobjectvar.connecttonewobject (“word. application”) 创建了新的winword.exe进程,但是没有执行关闭这个新的应用的操作。
3 解决
经过分析,我们可以确定了如何解决pb调用word的程序的问题。
打开文档
首先,我们使用<oleobjectvar>.connecttoobject(“<wordfilename>”)来打开一个空word文档。打开成功后,使用<oleobjectvar>.application获得对word.application的引用并设置applicatin.visible=true,并关闭刚才打开的空文档;
然后,使用word.application的open方法打开要使用的文档。
这样的方法打开文档,如果当前有正在运行的windows.exe进程,就不必打开新的进程,而是使用当前的进程,并且可以成功地对当前的进程获得引用。
关闭文档
首先,我们关闭程序打开的使用的文档;
然后判断application是否还有其他的打开的文档。如果没有其他打开的文档,则调用application的quit方法,让application退出,结束winword.exe的程序进程。如果确定以后还经常的调用word,也可以不关闭winword.exe的进程,这样可以每次很快的打开word的文档。
4 注意事项
由于通过oleobject调用word等office有许多限制。尽管这个方法能够解决许多问题,但是还是有许多需要特别注意的地方
第一,使用connecttoobject连接的文档,不能被锁定(比如被以前的进程打开,或者被当作模板新建立了一个文档,都可能锁定),否则将会产生未知错误(返回值-9);
第二,对document的各种操作,要保证word.application.visible=true,否则调用可能会产生程序错误。