OleWord时一些用用的代码

2024-04-26 16:38
文章标签 代码 用用 oleword

本文主要是介绍OleWord时一些用用的代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

[b]一、Delphi程序启动Word[/b]
采用CreateOleObjects的方法来启动Word,调用VBA代码,具体实现过程为:
首先使用GetActiveOleObject('Word.Application')判断当前内存中是否存在Word程序,如果存在,
则直接连接,如果没有Word程序,则使用CreateOleObject('Word.Application')启动Word

[b]二、Delphi程序新建Word文稿[/b]
格式:WordDocuments.Add(Template,NewTemplate,DocumentType,Visible)
Template:  使用模板的名称,
NewTemplate:  新建文档的类型,True表示为模板,False表示为文档
DocumentType:  文档类型,默认为空白文档
Visible:  打捞的窗口是否可见

举例:Doc_Handle:=Word_Ole.Documents.Add(Template:='C:/Temlate.dot',NewTemplate:=False);

[b]三、Delphi程序打开Word文稿[/b]
格式:WordDocuments.Open(FileName,ConfirmConversions,ReadOnly,PassWordDocument,
                         PasswordTemplate,Revent,WritePasswordDocument,WritePassWordTemplate,
                         Format,Encoding,Visible)

FileName:  文档名(包含路径)
Confirmconversions:  是否显示文件转换对话框
ReadOnly:  是否以只读方式打开文档
AddToRecentFiles:  是否将文件添加到"文件"菜单底部的最近使用文件列表中
PassWordDocument:  打开此文档时所需要的密码
PasswordTemplate:  打开此模板时所需要的密码
Revert:  如果文档已经,是否重新打开文档
WritePasswordDocument:  保存对文档更改时所需要的密码
WritePasswordTemplate:  保存对模板进行更改时所需要的密码
Format:  打开文档时所需使用的文件转换器
Encoding:  所使用的文档代码页
Visible:  打开文档的窗口是否可见

举例:
Doc_Handle:=Word_Ole.Documents.open(FileName:=Doc_File,ReadOnly:=False,
            AddToRecentFiles:=False);

[b]四、Delphi程序保存Word文稿[/b]
格式:WordDocuments.SaveAs(FileName, FileFormat, LockComments, Password,
                          AddToRecentFiles, WritePassword, ReadOnlyRecommended,
                          EmbedTrueTypeFonts, SaveNativePictureFormat, SaveFormsData,
                          SaveAsAOCELetter)

FileName:              文件名。默认为当前文件夹和文件名。
FileFormat              文档保存的格式。
LockComments            如果为 True,则此文档只允许进行批注。
Password                打开文档时的口令。
AddToRecentFiles        如果为True,则将文档添至"文件"菜单中最近使用的文档列表中。
WritePassword           保存对文档的修改所需的口令。
ReadOnlyRecommended     如果为 True,在每次打开文档时,Word 将建议用户采用只读方式。
EmbedTrueTypeFonts      如果为 True,则将文档与 TrueType 字体一起保存。
SaveNativePictureFormat  如果为 True,则从其他系统平台(例如 Macintosh)导入的图形仅保存其 Windows 版本。
SaveFormsData           如果为 True,则将窗体中用户输入的数据存为一条数据记录。
SaveAsAOCELetter        如果文档包含一个附加,当此属性值为 True 时,将文档存为一篇 AOCE 信笺(同时保存邮件)。

举例:
Word_Ole.Documents.SaveAs(FileName:=Doc_File,FileFormat=wdFormatDocument,
                          AddToRecentFiles=False);

[b]五、从数据库读取文件到本地硬盘和从本地硬盘读取文件到数据库[/b]

在数据库上使用Image二进制字段保存,使用Stream流的方式。

创建文件流:
     Word_FileStream:=TFileStream.Create(Target_Name,fmOpenWrite or fmCreate);
     Word_FileStream.Position:=0;

保存到数据库的Image字段:
     TBlobField(AdoQuery1.FieldByName(Column_Name)).SaveToStream(Word_FileStream);

从数据库读取文件到本地硬盘:
     TBlobField(ADOQuery1.FieldByName(Column_Name)).loadfromStream(Word_FileStream);

释放文件流:
     Word_FileStream.Free;

[b]六、全局消息的定义[/b]
因为word和Delphi程序是两个软件,相互之间通讯比较麻烦,所以使用全局消息的方法进行。
全局消息必须首先注册,Windows返回系统空闲的消息号,当注册的消息相同时,
Windows系统返回同一个值,这样就保证了使用这个消息号在两个程序之间通讯。

定义消息的办法:
    szMessageString: pchar = 'XIDIAN_11_Stone';
    FMyJoinMessage := RegisterWindowMessage(szMessageString);

发送消息的方法:
    SendMessage(对方句柄,消息,消息附带短变量,消息附带长变量)

[b]七、Delphi程序接收消息的方法[/b]
    Delphi接收消息有两种,一是重载特定消息,二是重载WndProc函数,在里面选择相应消息进行处理。
    法一,每次只能处理一条消息,而法二能够同时处理多条消息。

    对于法二,声明如下:
       procedure WndProc(var Message: TMessage);override
     必须注意,使用时需要在处理完自己消息处理后继承WndProc(Message)函数,否则系统会崩溃!

[b]八、Word中Combo对话框的动态生成以及Change事件[/b]
    建立类模块Combohander,在内部定义事件
      Public WithEvents ComboBoxEvent As Office.CommandBarComboBox

    定义Combo控件产生事件的模块
      Dim ctlComboBoxHandler As New ComboBoxHandler

    产生Combo对话框
      Set Cbo_ChooseDoc = CommandBars("添加的菜单").Controls.Add(Type:=msoControlComboBox, Temporary:=True)

    进行文件句柄设置,以产生Combo_Change事件
      Set ctlComboBoxHandler.ComboBoxEvent = Cbo_ChooseDoc

    产生事件后,在类模块Combohander内选择ComboBoxEvent的Change事件,即可书写事件代码
      Sub ComboBoxEvent_Change(ByVal Ctrl As Office.CommandBarComboBox)

[b]九、一些Word的事件[/b]
    VBA代码中处理的Word事件有:Document_Close
    Application事件中需要处理的有:DocumentBeforeClose,DocumentChange。

    Document_Close:事件在文档关闭时产生事件
    DocumentBeforeClose:在文档被关闭以前先于Word判断文档是否保存,给出相应提示并进行相应处理。
    DocumentChange:文档切换,在文档从自己修改的文稿和其他人修改的文稿之间切换产生事件,
主要处理设置文档权限等。
 

这篇关于OleWord时一些用用的代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/938100

相关文章

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

Java中ArrayList的8种浅拷贝方式示例代码

《Java中ArrayList的8种浅拷贝方式示例代码》:本文主要介绍Java中ArrayList的8种浅拷贝方式的相关资料,讲解了Java中ArrayList的浅拷贝概念,并详细分享了八种实现浅... 目录引言什么是浅拷贝?ArrayList 浅拷贝的重要性方法一:使用构造函数方法二:使用 addAll(

JAVA利用顺序表实现“杨辉三角”的思路及代码示例

《JAVA利用顺序表实现“杨辉三角”的思路及代码示例》杨辉三角形是中国古代数学的杰出研究成果之一,是我国北宋数学家贾宪于1050年首先发现并使用的,:本文主要介绍JAVA利用顺序表实现杨辉三角的思... 目录一:“杨辉三角”题目链接二:题解代码:三:题解思路:总结一:“杨辉三角”题目链接题目链接:点击这里

SpringBoot使用注解集成Redis缓存的示例代码

《SpringBoot使用注解集成Redis缓存的示例代码》:本文主要介绍在SpringBoot中使用注解集成Redis缓存的步骤,包括添加依赖、创建相关配置类、需要缓存数据的类(Tes... 目录一、创建 Caching 配置类二、创建需要缓存数据的类三、测试方法Spring Boot 熟悉后,集成一个外

轻松掌握python的dataclass让你的代码更简洁优雅

《轻松掌握python的dataclass让你的代码更简洁优雅》本文总结了几个我在使用Python的dataclass时常用的技巧,dataclass装饰器可以帮助我们简化数据类的定义过程,包括设置默... 目录1. 传统的类定义方式2. dataclass装饰器定义类2.1. 默认值2.2. 隐藏敏感信息

opencv实现像素统计的示例代码

《opencv实现像素统计的示例代码》本文介绍了OpenCV中统计图像像素信息的常用方法和函数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 统计像素值的基本信息2. 统计像素值的直方图3. 统计像素值的总和4. 统计非零像素的数量

IDEA常用插件之代码扫描SonarLint详解

《IDEA常用插件之代码扫描SonarLint详解》SonarLint是一款用于代码扫描的插件,可以帮助查找隐藏的bug,下载并安装插件后,右键点击项目并选择“Analyze”、“Analyzewit... 目录SonajavascriptrLint 查找隐藏的bug下载安装插件扫描代码查看结果总结Sona

Python开发围棋游戏的实例代码(实现全部功能)

《Python开发围棋游戏的实例代码(实现全部功能)》围棋是一种古老而复杂的策略棋类游戏,起源于中国,已有超过2500年的历史,本文介绍了如何用Python开发一个简单的围棋游戏,实例代码涵盖了游戏的... 目录1. 围棋游戏概述1.1 游戏规则1.2 游戏设计思路2. 环境准备3. 创建棋盘3.1 棋盘类

Java实现批量化操作Excel文件的示例代码

《Java实现批量化操作Excel文件的示例代码》在操作Excel的场景中,通常会有一些针对Excel的批量操作,这篇文章主要为大家详细介绍了如何使用GcExcel实现批量化操作Excel,感兴趣的可... 目录前言 | 问题背景什么是GcExcel场景1 批量导入Excel文件,并读取特定区域的数据场景2