ImageVerifierCode 换一换
格式:DOCX , 页数:28 ,大小:63.25KB ,
资源ID:9526624      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/9526624.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(Word VBA学习交流资料之二.docx)为本站会员(b****7)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

Word VBA学习交流资料之二.docx

1、Word VBA学习交流资料之二Word VBA 学习交流资料之二感想:有感于国人的Word水平比较低,尤其是VBA这一块,本人想请大家一起学习VBA,在提高自身的能力同时帮助需要帮助的人。感谢:绿叶的建群之功,也感谢you兄的热烈支持,更感谢大家的大力支持!学前必备:Word VBA帮助(2003或别的都行,大体相当)(没有也没有关系,在这里,大多看到的就是复制自“帮助”的。)可选工具:金山词霸(对E文不太懂的人,尤其重要)语法工具:共享区的“VBA一串通”学习方法:“不求甚解”(一开始,不太懂,没关系,坚持下去就懂了。)学习步骤:看到例子时,复制到VBE编辑器中运行一次,看一下结果(最好按

2、F8,一步一步地看)必要指出:是“互学”,错误或不妥之处难免!因我也是一边看帮助,一边写。开始之前:高唱国歌(最好能喊:自强不息!)Start:一、通过录制宏生成代码如果无法确定要使用的 Visual Basic 方法或属性,可打开宏录制器并进行手动操作。宏录制器会将操作译成 Visual Basic 代码。录制操作完成后,可根据需要修改代码。例如,如果无法确定实现段落缩进的属性或方法,可执行下列操作:1. 在“工具”菜单上,指向“宏”,然后单击“录制新宏”。 2. 如果需要,可更改默认的宏名称,然后单击“确定”启动录制器。 3. 在“格式”菜单上,选定“段落”。 4. 更改段落左缩进的值,然

3、后单击“确定”。 5. 单击“停止录制”工具栏上的“停止录制”按钮。 6. 在“工具”菜单上,指向“宏”,然后单击“宏”。 7. 从步骤 2 中选择宏的名称,然后单击“编辑”按钮。 查看 Visual Basic 代码来确定对应于段落左缩进的属性(LeftIndent 属性)。将插入点置于 LeftIndent 之中,并按 F1 或单击“帮助”按钮。在帮助主题中,可以查看示例以及支持 LeftIndent 属性的对象(单击“应用于”)。(从上面可以看出,录制宏是我们认识未知对象的很好方法之一,同时,也知道我为什么要大家装“金山词霸”的原因!如果你这个单词不认识,你怎么知道他是“左缩进”?当然,

4、也有方法:就是把这个值设为一个比较特殊的值,再打特殊值所对应的属性)说明录制的宏使用 Selection 属性返回 Selection 对象。例如,下列指令将所选段落缩进 0.5 英寸。Sub IndentParagraph() Selection.ParagraphFormat.LeftIndent = InchesToPoints(0.5)End Sub您也可以修改录制的宏并与 Range 对象一起使用。(我们在日常的使用中经常注意到:在使用“本机上的模板”是的向导就大量使用了Selection对象,而不是Range对象!难道说微软有更新层次的考虑?我想可能是Selection对象更稳定,

5、跨版本能力更强吧!)二、修改录制的 Visual Basic 宏宏录制器是查找所需的 Visual Basic 方法和属性的非常方便的工具。如果不知道使用何种属性或方法,可打开宏录制器,手动执行操作。宏录制器会将操作译为 Visual Basic 代码。但录制宏具有一些限制条件。您不能录制下列内容:条件分支 变量指定 循环结构 自定义用户窗体 出错处理 用鼠标选定的文字(必须使用组合键) 若要增强宏的功能,可能需要修改录制到模块中的代码。删除 Selection 属性使用宏录制器创建的宏取决于所选内容。在大多数录制的宏指令的开头,可以看到“Selection”。录制的宏使用 Selection

6、 属性返回 Selection 对象。例如,下列示例将所选内容移动至 Temp 书签,并在书签之后插入文字。Sub Macro1() Selection.Goto What:=wdGotoBookmark, Name:=Temp Selection.MoveRight Unit:=wdCharacter, Count:=1 相当于选中后按一个键盘的右方向键 Selection.TypeText Text:=New textEnd Sub这个宏虽然可以完成任务,但是有一些缺点。首先,如果文档中没有一个名为 Temp 的书签,该宏将导致出错。其次,该宏可能不正确地移动所选内容。修改这个宏,使其不再

7、使用 Selection 对象,就可解决上述两个问题。以下就是经修改后的宏:Sub MyMacro()If ActiveDocument.Bookmarks.Exists(Temp) = True Then endloc = ActiveDocument.Bookmarks(Temp).End ActiveDocument.Range(Start:=endloc, _ End:=endloc).InsertAfter New text_就是续行的意思End IfEnd SubExists 方法用于检查是否存在名为 Temp 的书签。如果找到该书签,则用 End 属性返回该书签结束字符的位置。最

8、后使用 Range 方法返回一个引用书签结束位置的 Range 对象,以使用 InsertAfter 方法插入文字。有关定义 Range 对象的详细信息,请参阅处理 Range 对象。使用 WithEnd With可使用 WithEnd With 结构简化引用相同对象的宏指令。例如,在文档顶部添加标题时,将录制下面的宏。Sub Macro1() Selection.HomeKey Unit:=wdStory Selection.TypeText Text:=Title Selection.ParagraphAlignment.Alignment = wdAlignParagraphCenter

9、End Sub每个指令都使用 Selection 属性返回一个 Selection 对象。可以简化这个宏,这样只需使用一次 Selection 属性。Sub MyMacro() With Selection .HomeKey Unit:=wdStory .TypeText Text:=Title .ParagraphAlignment.Alignment = wdAlignParagraphCenter 上面那句是原帮助中的,但肯定是笔误!微软没看出?! .ParagraphFormat.Alignment = wdAlignParagraphCenter End WithEnd Sub不使用

10、 Selection 对象也可以完成相同的任务。下面的宏在活动文档的开头使用 Range 对象来完成相同的任务。Sub MyMacro() With ActiveDocument.Range(Start:=0, End:=0) .InsertAfter Title .ParagraphAlignment.Alignment = wdAlignParagraphCenter 上面那句是原帮助中的,但肯定是笔误!微软没看出?! .ParagraphFormat.Alignment = wdAlignParagraphCenter End WithEnd Sub删除不必要的属性如果录制了一个关于在对

11、话框中选择选项的宏,即使只更改一个或两个选项,宏录制器也会记录该对话框中的所有选项的设置。如果不希望更改所有的选项,可从录制的宏中删除不必要的属性。下面录制的宏包含“段落”对话框的一些选项(单击“格式”菜单可显示该对话框的所有信息)。Sub Macro1() With Selection.ParagraphFormat .LeftIndent = InchesToPoints(0) 左缩进0英寸 .RightIndent = InchesToPoints(0) 右缩进0英寸 .SpaceBefore = 6 段前距6磅 .SpaceAfter = 6 段后距6磅,下面不写了! .LineSpa

12、cingRule = 0 .Alignment = wdAlignParagraphLeft .WidowControl = True .KeepWithNext = False .KeepTogether = False .PageBreakBefore = False .NoLineNumber = False .Hyphenation = True .FirstLineIndent = InchesToPoints(0) .OutlineLevel = 10 End WithEnd Sub但是,如果只需更改段前和段后间距,可将宏更改为:Sub MyMacro() With Selecti

13、on.ParagraphFormat .SpaceBefore = 6 .SpaceAfter = 6 End WithEnd Sub因为只设置了较少的属性,所以简化后的宏运行得更快。运行结果只更改选定段落的段前和段后的间距,所有其他设置都没有改变。(注意:如果你是一个喜欢乱动的人,还是要上面吧,但他的速度肯定没有下面的快,但他的适合环境更大.更所谓忠孝难两全啊-)删除不必要的参数当宏录制器记录一个方法时,会包含所有参数的值。打开名为 Test.doc 的文档时,录制了下面的宏。所得到的宏包含 Open 方法的所有参数。Sub Macro1() Documents.Open FileName:

14、=C:My DocumentsTest.doc, _ ConfirmConversions:= False, ReadOnly:=False, _ AddToRecentFiles:=False, PasswordDocument:=, _ PasswordTemplate:=, Revert:=False, _ WritePasswordDocument:=, _ WritePasswordTemplate:=, Format:=wdOpenFormatAutoEnd Sub可以从录制的宏中删除不需要的参数。例如,可以删除所有设置为空字符串的参数(如 WritePasswordDocumen

15、t:=),如下所示。Sub MyMacro() Documents.Open FileName:=C:My DocumentsTest.doc, _ ConfirmConversions:= False, _ ReadOnly:=False, AddToRecentFiles:=False, _ Revert:=False, Format:=wdOpenFormatAutoEnd Sub三、自动运行的宏通过为一个宏赋予某个特殊的名称,就可在执行某项操作(例如启动 Word 或打开文档)时自动运行宏。Word 将下列名称识别为自动宏,或称“auto”宏。宏名运行条件AutoExec启动 Word

16、 或加载全局模板时AutoNew每次新建文档时AutoOpen每次打开已有文档时AutoClose每次关闭文档时AutoExit退出 Word 或卸载全局模板时当以下条件之一为真时,将识别代码模块中的自动宏。 模块在自动宏(如 AutoExec)之后命名,并且包含一个名为“Main”的过程。 任何模块中的过程在自动宏之后命名。 与其他宏一样,自动宏也可以保存于 Normal 模板、其他模板或文档中。要让自动宏运行,它必须位于活动文档的 Normal 模板中,或活动文档选用的模板中。唯一例外的是 AutoExec 宏,它只有存储于以下位置时才可自动运行:Normal 模板、通过“模板和加载项”对

17、话框全局加载的模板、或由“Startup”文件夹指定的文件夹中的全局模板。在命名冲突的情况下(多个自动宏名相同),Word 将运行上下文中最近的自动宏。例如,如果同时在文档及其附加的模板中创建了 AutoClose 宏,则仅执行文档中的自动宏。如果在 Normal 模板中创建了 AutoNew 宏,只有当文档或其附加模板中没有名为 AutoNew 的宏时,该自动宏才能运行。(笔者注:简称就近原则!)注释按住 Shift 可以终止自动宏的运行。例如,基于包含 AutoNew 宏的模板新建文档时,按住 Shift 可终止 AutoNew 宏的运行。方法是:按住 Shift,单击(“文件”菜单)“新

18、建”对话框中的“确定”按钮,并在显示新文档前持续按住 Shift。如果运行一个宏时有可能触发自动宏,(这种情况,我没遇过!)可用下列指令终止自动宏的运行:WordBasic.DisableAutoMacros四、修改 Word 命令大多数 Word 命令都可通过转换为宏的方式对其进行修改。例如,可修改“文件”菜单上的“打开”命令,使其不再显示 Word 文档文件列表(扩展名为 .doc 的文件),而显示当前文件夹中的所有文件。若要在“宏”对话框中显示内置 Word 命令列表,可在“宏的位置”框中选定“Word 命令”。显示的命令列表中包含所有的菜单命令、工具栏命令或快捷键命令。菜单命令名称以相

19、关的菜单名称开头。例如,“文件”菜单中的“保存”命令显示为“FileSave”。方法是工具/宏/宏通过将一个宏命名为与 Word 命令相同的名称,就可用宏替代 Word 命令。例如,如果创建一个名为“FileSave”的宏,当选择“文件”菜单上的“保存”命令、单击“保存”工具栏按钮,或按“保存文件”快捷键时,Word 将运行该宏。本示例介绍了修改 FileSave 命令的步骤。1. 在“工具”菜单上,指向“宏”,然后单击“宏”。 2. 在“宏的位置”框中,选择“Word 命令”。 3. 在“宏名”框中,选择“FileSave”。 4. 在“宏的位置”框中选择一个模板或文档以保存该宏。例如,选择

20、 Normal.dot(全局模板)可生成一个共用宏(即修改所有文档的“FileSave”命令)。5. 单击“创建”按钮。 FileSave 宏显示如下:Sub FileSave() FileSave Macro Saves the active document or template ActiveDocument.SaveEnd Sub可添加指令或删除现有的 ActiveDocument.Save 指令。之后在运行“FileSave”命令时,新的 FileSave 宏将取代 word 命令。若要恢复“FileSave”原有的功能,需重新命名新的 FileSave 宏或将之删除。说明: 也可以

21、创建与 Word 命令同名的代码模块(例如 FileSave)并包含名为 Main 的子程序,以此替换 Word 命令。五、将文本插入文档使用 InsertAfter 或 InsertBefore 方法在 Selection 或 Range 对象之前或之后插入文字。下列示例在活动文档的末尾插入文字。Sub InsertTextAtEndOfDocument() ActiveDocument.Content.InsertAfter Text:= The end.End Sub下列示例在所选内容之前插入文字。Sub AddTextBeforeSelection() Selection.Insert

22、Before Text:=new text End SubRange 对象或 Selection 对象在使用了 InsertBefore 或 InsertAfter 方法之后,会扩展并包含新的文本。使用 Collapse 方法可以将 Selection 或 Range 折叠到开始或结束位置。六、选定文档中的文本可使用 Select 方法选定文档中的对象。Select 方法可用于多种对象,例如 Bookmark、Field、Range 和 Table 对象。下列示例选定活动文档中的第一个表格。Sub SelectTable() ActiveDocument.Tables(1).SelectEnd

23、 Sub下列示例选定活动文档中的第一个域。Sub SelectField() ActiveDocument.Fields(1).SelectEnd Sub下列示例选定活动文档中的前四个段落。Range 方法用于创建一个引用前四个段落的 Range 对象,然后将 Select 方法应用于 Range 对象。Sub SelectRange() Dim rngParagraphs As Range Set rngParagraphs = ActiveDocument.Range( _ Start:=ActiveDocument.Paragraphs(1).Range.Start, _ End:=Ac

24、tiveDocument.Paragraphs(4).Range.End) rngParagraphs.SelectEnd Sub选定文档中的文本:我觉得用处不大,原因就是为什么要选中呢?能操作就直接操作,不能的话,就选中吧(他可以说是没办法的办法).七、编辑文字本主题包含与下列任务相关的 Visual Basic 示例: 确定文本是否被选定 折叠选定内容或区域 扩展选定内容或区域 重新定义 Range 对象 更改文本 有关其他编辑任务的信息和示例,请参阅下列主题:从文档返回文本 选定文档中的文本 将文本插入文档 修改文档的某一部分 确定文本是否被选定Selection 对象的 Type 属性

25、返回所选内容类型的信息。如果所选内容为插入点,则下列示例显示一条消息Nothing is Selected。没选中任何问题Sub IsTextSelected() If Selection.Type = wdSelectionIP Then MsgBox Nothing is selectedEnd Sub折叠所选内容或区域使用 Collapse 方法可将 Selection 或 Range 对象折叠到开始或结束点的位置。下列示例在所选内容的开头将所选内容折叠为一个插入点。Sub CollapseToBeginning()Selection.Collapse Direction:=wdColl

26、apseStartSelection.Collapse Direction:=wdCollapseEndEnd Sub这个是标准的折叠的程序,以后可能会用到的噢!下列示例将区域折叠至其结束点(在第一个单词之后),并添加新文本。Sub CollapseToEnd() Dim rngWords As Range Set rngWords = ActiveDocument.Words(1) 设置第一个单词为区域rngWords With rngWords .Collapse Direction:=wdCollapseEnd 折叠到最后,区域与可以折叠的噢! .Text = (This is a te

27、st.) 在折叠的最后加入这些文字 End WithEnd Sub扩展所选内容或区域下列示例使用 MoveEnd 方法扩展所选内容的结尾以包含三个附加的单词(总共是4个!)。MoveLeft、MoveRight、MoveUp 和 MoveDown 方法也可以用于扩展 Selection 对象。Sub ExtendSelection() Selection.MoveEnd Unit:=wdWord, Count:=3End Sub下列示例使用 MoveEnd 方法扩展区域,以包含活动文档中的前三个段落。Sub ExtendRange() Dim rngParagraphs As Range Se

28、t rngParagraphs = ActiveDocument.Paragraphs(1).Range rngParagraphs.MoveEnd Unit:=wdParagraph, Count:=2End Sub重新定义 Range 对象使用 SetRange 方法可重新定义现有的 Range 对象。更改文字通过更改某一区域中的内容可更改现有的文字。下列指令通过将 Text 属性设为“The”来更改活动文档中的第一个单词。Sub ChangeText() ActiveDocument.Words(1).Text = The End Sub也可以使用 Delete 方法删除现有文本,然后使

29、用 InsertAfter 或 InsertBefore 方法插入新文本。下列示例删除活动文档的第一段,并插入新文本。Sub DeleteText() Dim rngFirstParagraph As Range Set rngFirstParagraph = ActiveDocument.Paragraphs(1).Range With rngFirstParagraph .Delete .InsertAfter Text:=New text .InsertParagraphAfter End WithEnd Sub上面的这个例子我们通常不用,我们更喜欢用下面Sub DeleteText1(

30、) Dim rngFirstParagraph As Range Set rngFirstParagraph = ActiveDocument.Paragraphs(1).Range rngFirstParagraph.Text = New text & Chr(13)End Sub八、将格式应用于文本本主题包含与下列任务相关的 Visual Basic 示例: 将格式应用于选定内容 将格式应用于某一区域 插入文本并应用字符和段落格式 在 12 磅和无之间切换段前间距 切换加粗格式 将左边距增加 0.5 英寸 将格式应用于选定内容下列示例使用 Selection 属性将字符和段落格式应用于选定文本。使用 Font 属性获得字体格式的属性和方法,使用 ParagraphFormat 属性获得段落格式的属性和方法。Sub FormatSelection() With Selection.Font .Name = Times New Roman .Size = 14 .AllCaps = True 全部大写 End With With Selection.ParagraphFormat .LeftIndent = InchesToPoints(0.5) 左缩进0.5英寸 .Space1 这是单倍行距的缩写 End WithEnd Sub将格式应用于某

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1