delphi操作word


======================================================
注:本文源代码点此下载
======================================================

delphi操作word

一、delphi程序启动word

采用createoleobjects的方法来启动word,调用vba代码,具体实现过程为:

首先使用getactiveoleobject('word.application')判断当前内存中是否存在word程序,如果存在,

则直接连接,如果没有word程序,则使用createoleobject('word.application')启动word

二、delphi程序新建word文稿

格式:worddocuments.add(template,newtemplate,documenttype,visible)

template: 使用模板的名称,

newtemplate: 新建文档的类型,true表示为模板,false表示为文档

documenttype: 文档类型,默认为空白文档

visible: 打捞的窗口是否可见

举例:doc_handle:=word_ole.documents.add(template:='c:\temlate.dot',newtemplate:=false);

三、delphi程序打开word文稿

格式: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);

四、delphi程序保存word文稿

格式: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);

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

在数据库上使用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;

六、全局消息的定义

因为word和delphi程序是两个软件,相互之间通讯比较麻烦,所以使用全局消息的方法进行。

全局消息必须首先注册,windows返回系统空闲的消息号,当注册的消息相同时,

windows系统返回同一个值,这样就保证了使用这个消息号在两个程序之间通讯。

定义消息的办法:

szmessagestring: pchar = 'xidian_11_stone';

fmyjoinmessage := registerwindowmessage(szmessagestring);

发送消息的方法:

sendmessage(对方句柄,消息,消息附带短变量,消息附带长变量)

七、delphi程序接收消息的方法

delphi接收消息有两种,一是重载特定消息,二是重载wndproc函数,在里面选择相应消息进行处理。

法一,每次只能处理一条消息,而法二能够同时处理多条消息。

对于法二,声明如下:

procedure wndproc(var message: tmessage);override

必须注意,使用时需要在处理完自己消息处理后继承wndproc(message)函数,否则系统会崩溃!

八、word中combo对话框的动态生成以及change事件

建立类模块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)

九、一些word的事件

vba代码中处理的word事件有:document_close

application事件中需要处理的有:documentbeforeclose,documentchange。

document_close:事件在文档关闭时产生事件

documentbeforeclose:在文档被关闭以前先于word判断文档是否保存,给出相应提示并进行相应处理。

documentchange:文档切换,在文档从自己修改的文稿和其他人修改的文稿之间切换产生事件,

主要处理设置文档权限等。

在dephi &中提供了一组servers组件,实现了与office的无缝结合

1、在当前程序目录下建立以标题字段命名的word文件

exepath:=application.exename;

for index:=1 to length(exepath) do

if exepath[index]='\' then

i:=index;

exepath:=copy(exepath,1,i);

doc_file:=exepath+mc+'.doc';

以标题字段"mc"命名word文件

try

wordapplication1.connect;

except

messagedlg('没有安装word',mterror,[mbok],0);

abort;

end;

wordapplication1.caption := 'xx计划书';

wordapplication1.visible := true;

worddocument1.activate;

2、设置纸张大小

wordapplication1.activedocument.pagesetup.pagewidth:=xxx;

wordapplication1.activedocument.pagesetup.pageheight:=xxx;

wordapplication1.activedocument.pagesetup.leftmargin := xx;

//设置左边距

wordapplication1.activedocument.pagesetup.rightmargin := xx;

//设置右边距

3、插入页码

var fpage,pagea:olevariant;

fpage:=true;

pagea:=wdalignpagenumbercenter;

wordapplication1.activedocument.sections.item(1).footers.item(1).pagenumbers.add(pagea,fpage);

4、设置页面横向打印

s:=wordapplication1.selection.start;

e:=wordapplication1.selection.start;

aa:=wdsectionbreaknextpage;

wordapplication1.activedocument.range(s,e).insertbreak(aa);

wordapplication1.selection.start:=wordapplication1.selection.start + 1;

s:=wordapplication1.selection.start;

e:=wordapplication1.activedocument.content.end_;

wordapplication1.activedocument.range(s,e).pagesetup.orientation:=wdorientlandscape;

5、设置字体、字号

wordapplication1.selection.font.size:=18;

wordapplication1.selection.font.name := '黑体';

wordapplication1.selection.typeparagraph;

wordapplication1.selection.paragraphformat.alignment:= wdalignparagraphcenter;

wordapplication1.selection.typeparagraph;

wordapplication1.selection.typetext(dbedit4.text);

//标题

wordapplication1.selection.font.size := 14;

wordapplication1.selection.font.name := '宋体';

wordapplication1.selection.typeparagraph;

wordapplication1.selection.typeparagraph;

wordapplication1.selection.paragraphformat.alignment := wdalignparagraphjustify;

wordapplication1.selection.typetext(' '+trim(dbmemo1.text));

//正文

... ...

6、插入表格

wordapplication1.selection.font.size :=10;

adoquery2.active:=false;

adoquery2.active:=true;

doc:=wordapplication1.activedocument;

counts:=adoquery2.recordcount;

//记录数决定表格的行数

t:=doc.tables.add(wordapplication1.selection.range,counts+1,5);//5列

t.cell(1,1).range.text:= '单位';

t.cell(1,1).width:=120;

t.cell(1,1).range.paragraphs.alignment:= wdalignparagraphcenter;

t.cell(1,2).range.text:= '姓名';

... ...

//依次写入其他字段的表头

for i:=2 to counts+1 do

begin

t.cell(i,1).range.text:=adoquery2.field

byname('dw').asstring;

t.cell(i,1).width:=120;

t.cell(i,1).range.paragraphs.alignment:=

wdalignparagraphcenter;

t.cell(i,2).range.text:=adoquery2.field

byname('xm').asstring;

... ...

adoquery2.next;

end;

使用dephi将word与数据库结合,实现了用户文档的自动生成,大大地方便了用户。

作者:易简.道

出处:http://www.cnblogs.com/xyicheng/

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

绿色通道:好文要顶关注我收藏该文与我联系


======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值