VB查找并替换WORD文档中的字符串

2016-02-19 14:20 76 1 收藏

人生本是一个不断学习的过程,在这个过程中,图老师就是你们的好帮手,下面分享的VB查找并替换WORD文档中的字符串懂设计的网友们快点来了解吧!

【 tulaoshi.com - 编程语言 】

基本要求:需安装WORD
  
  FunctionWordReplace(FileNameAsString,SearchStringAsString,ReplaceStringAsString,OptionalSaveFileAsString="",OptionalMatchCaseAsBoolean=False)AsInteger
  OnErrorGoToErrorMsg'函数运行时发生遇外或错误,转向错误提示信息
  
  DimwordAppAsNewWord.Application
  DimwordDocAsNewWord.Document
  DimwordArangeAsWord.Range
  DimwordSelectionAsWord.Selection
  DimReplaceSignAsBoolean
  DimIAsInteger
  
  
  '判断将要替换的文件是否存在
  IfDir(FileName)=""Then
  '替换文件不存在
  MsgBox"未找到"&FileName&"文件"'提示替换文件不存在信息
  WordReplace=-2'返回替换文件不存在的值
  ExitFunction'退出函数
  EndIf
  
  SetwordApp=CreateObject("Word.Application")'建立WORD实例
  wordApp.Visible=False'屏蔽WORD实例窗体
  SetwordDoc=wordApp.Documents.Open(FileName)'打开文件并赋予文件实例
  SetwordSelection=wordApp.Selection'定位文件实例
  SetwordArange=wordApp.ActiveDocument.Range(0,1)'指定文件编辑位置
  wordArange.Select'激活编辑位置
  
  I=0'初始化替换次数值
  ReplaceSign=True'初始化是否替换成功标志
  DoWhileReplaceSign
  ReplaceSign=wordArange.Find.Execute(SearchString,MatchCase,,,,,,wdFindContinue,,ReplaceString,True)'查找并替换
  '判断查找并替换是否成功,如果成功替换次数值递增1
  IfReplaceSign=TrueThen
  I=I 1
  EndIf
  Loop
  
  MsgBox"已完成对文档的搜索并完成"&I&"替换。"'提示总替换次数
  
  '如果替换成功,则提示是否保存
  IfI0Then
  '判断是否需要另存
  IfTrim(SaveFile)""Then
  '需要另存
  IfDir(SaveFile)=""Then
  wordDoc.SaveAsSaveFile'文件另存为……
  Else
  '咨询是否替换文件,如果不替换则放弃本次操作,否则存在本次操作
  IfMsgBox("是否替换"&SaveFile&"文件?",vbYesNo vbQuestion,"替换")=vbYesThen
  wordDoc.SaveAsSaveFile'文件另存为……
  EndIf
  EndIf
  Else
  IfMsgBox("是否保存对"&SaveFile&"更改?",vbYesNo vbQuestion,"保存")=vbYesThen
  wordDoc.Save'保存在原文件中
  EndIf
  EndIf
  EndIf
  
  WordReplace=I'返回替换次数
  
  wordDoc.Close'关闭文档实例
  wordApp.Quit'关闭WORD实例
  SetwordDoc=Nothing'清除文件实例
  SetwordApp=Nothing'清除WORD实例
  
  
  ExitFunction
  
  
  ErrorMsg:
  MsgBoxErr.Number&":"&Err.Description'提示错误信息
  WordReplace=-1'返回错误信息值
  wordDoc.Close'关闭文档实例
  wordApp.Quit'关闭WORD实例
  SetwordDoc=Nothing'清除文件实例
  SetwordApp=Nothing'清除WORD实例
  
  EndFunction
  
  注意事项:单击在菜单“工程”中的“引用”菜单项,弹出窗口,在列表框中选择“MicrosoftWordXObjectLibaray“,单击引用
  
  在VB6.0 OfficeXP Windows测试通过->

来源:http://www.tulaoshi.com/n/20160219/1606761.html

延伸阅读
标签: ASP
  自己可以修改myreplace函数,实现复杂的替换.呵呵,好象用处不大.主要是看看如何读取access表和字段列表 <% '#################################### '替换数据库内容 lamking 2005-8-22 'http://www.lamking.com QQ:628557 '#################################### Dim Db,Connstr,conn,rs,rs2,str1,str2,I str1="abcd" '要替换的字符...
标签: Web开发
一、概述     字符串在javascript中几乎无处不在,在你处理用户的输入数据的时候,在读取或设置DOM对象的属性时,在操作cookie时,当然还有更多...。JavaScript的核心部分提供了一组属性和方法用于通用的字符串操作,如分割字符串,改变字符串的大小写,操作子字符串等。     当前的大部分浏览器也能从强大的...
标签: ASP
  自己可以修改myreplace函数,实现复杂的替换.呵呵,好象用处不大.主要是看看如何读取access表和字段列表 <% '#################################### '替换数据库内容 lamking 2005-8-22 'http://www.lamking.com QQ:628557 '#################################### Dim Db,Connstr,conn,rs,rs2,str1,str2,I str1="abcd" '要替换的字符...
标签: 电脑应用
Word查找替换不仅可以帮助我们快速的定位到想要的内容,还可以让我们批量修改文章中相应的内容。 有很多人只知道“查找替换”功能可以批量修改文字,不仅仅是这样,今天Word联盟所要讲的是查找替换所有的使用功能大全,各种各样的用法,为的就是能在以后的处理文档时更加方便,希望大家可以灵活运用,即学即用。 一、最基...
使用正则表达式进行替换: 代码片段: String documentTxt = EntityUtils.toString(entity,"gbk");//获取数据 documentTxt=documentTxt.replaceAll("[\\t\\n\\r]", "");//将内容区域的回车换行去除 说明:String类的replaceAll就有正则替换功能。 \t为制表符 \n为换行 \r为回车 java正则使用: 示例方法: 代码如下: public void par...

经验教程

406

收藏

48
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部