下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、在PB中实现Word内容的替换 微电脑世界 作者:张佐东 汤咏梅2003-1-11 15:32:49 本文介绍一种在Power Builder(以下简称为PB)中利用OLE把数据库中的数据传送到Word文档的方法。通过这种方法,用户可以根据需求而改变内容,以Word方式打印结果文档。例如,在处理学生成绩时,如果要将每个学生的成绩报告生成Word文档,不同的学生只改变姓名、学号和年度等数据,其他的格式不改变。只要从学生成绩数据库中调出特定数据,插入或替换到已经制作好的Word模版中,即可解决问题。 一、创建Word模版文档 Word模板文档的创建根据用户的要求进行,在固定的内
2、容输入完成后,将需要变换内容(例如姓名、年度、系别和证书编号等)的位置输入“student_name”、“student_year”、“department”以及“student_id”等编码。注意: 尽量使用英文来表示这些变量,目的是避免某些汉字相同而造成的误替换。 在需要动态改变内容的位置,不需要输入文字,可以通过插入书签的方法实现,具体操作如下。首先,选择在Word中,选择“插入”*“书签”,弹出“书签”对话框(如图1所示)。在“书签名”文本框中输入书签名称后,点击“添加”按钮,即在当前光标位置上增加了一个书签。假设我们增加了4个书签,分别是 name、year、department以及
3、id,分别代表姓名、年度、系别以及证书编号。 二、PB实现方法 在窗体中新建一OLE控件,在弹出的“insert object”属性窗口的“create new tab”选项卡中选择“Microsoft Word 文档”选项,点击“OK”按钮后将该控件放在窗体中适当位置,PB系统会自动出现Microsoft Word应用程序。将控件命名为“OLE_Word”,并创建“打开文件”、“替换数据”和“存盘”按钮,编写如下代码。 1打开文件 string docname, named integer value value = getfileopenname("Select File&quo
4、t;,docname, named, "DOC","Doc Files (*.DOC),*.DOC") if value = 1 THEN / 将模版文件另存为实际操作文件(程序略) if ole_Word.open(docname)=0 then ole_Word.activate(inplace!) end if end if 这里使用“GetFileOpenName”函数让用户自行选择文件,实际应用时可以进行条件的限定。注意: 需要将模版文件另存为实际操作文件后再打开,不能直接操作模版文件。打开文件参数有2种,其中“inplace”表示在PB程序内
5、部窗口调用Word,部分提供Word的功能菜单; 另一种参数是“offsite”,表示PB程序外启动Word应用程序,提供Word的所有功能菜单。简单的演示文档如图2所示。 2插入或替换操作 (1)替换数据法 string ls_find_string,ls_replace_string /取数据库中数据赋值变量ls_replace_string(程序略) ls_find_string = "student_name" ls_replace_string = “张某” ole_Word.object.application.Selection.find.Execute(ls
6、_find_string,false,true,false,false,false,true,1,true,ls_replace_string,2) /替换student_year,department,student_id的程序与替换student_name相同,略 其运行结果如图3所示。 (2)插入数据法 除了使用查找替换方式,您还可以使用书签方式来实现上述操作。 string ls_name,ls_year,department,ls_id/取数据库中数据赋值变量ls_name,ls_year,department,ls_id(程序略) IF ole_Word.object.applic
7、ation.ActiveDocument.Bookmarks.Exists(“name”) THEN ole_Word.object.application.activedocument.bookmarks.item(“name”).select/定位书签name ole_Word.object.application.selection.typetext(ls_name)/插入值 for i = 1 to 10 /消除非法字符 ole_Word.object.application.Selection.TypeBackspace() next ELSE/错误提示 END IF /定位书签year,department,id一样,略 注意事项: 1一定要判断书签是否存在,如果书签不存在,进行以上操作将导致系统错误。 2因为汉字双字节问题,PB 6.5中每插入一个汉字后会在后面产生一非法字符,需要判断汉字个数来决定调用“TypeBackspace()”的次数。上面涉及的10次循环次数是举例说明,实际编程要使用变量替代。 上面的2种方法各有利弊,插入数据方式设计思想简单,操作容易,控制也比较方便,但不适合多处插入同一内容,并且需要删除产生的非法字符; 而替换方式只调用一个函数,可以搜索整个文档替换同一
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 河北邢台市2026年银行业专业人员中级职业资格考试(专业实务个人理财)试题及答案
- 2026音乐综合测试面试题及答案
- 2026年人力资源岗位校招笔试题含答案
- 2026年京东自营直通车售前售后客服认证初级考试答案及题库
- 2026年3月15日九江市五类人员面试真题及答案解析
- 废旧纺织生产线部分技术和设备改造项目可行性研究报告模板-申批备案
- 浙江银行招聘杭州银行零售信贷中心招聘考试真题及答案
- 关于2026年合作伙伴年度总结会议的邀请函(6篇范文)
- 家庭教育专家亲子教育方法指导书
- 2026年广东佛山南海区桂城街道社区工作者招聘考试核心押题卷(第1套)(附独家高分解析)
- 2026-2030中国白色家电行业深度调研及投资前景预测研究报告
- 宠物美容师职业技能等级认定考试复习题库(附答案)
- 2025年新媒体运营师(中级)考试真题试卷及详细答案
- 光伏围栏施工安装合同参考样本合同
- 医学生求职简历模板
- GB/T 31458-2026医院安全防范要求
- 中日it行业对比分析报告
- 工地宿舍卫生奖罚制度
- 生产车间易耗品领用制度
- 电商直播介绍
- 2026年上半年党风廉政建设工作总结及下半年计划汇报报告
评论
0/150
提交评论