VBA之Word应用:批量替换模板中固定字段的内容并另存为新文件

发布于:2024-08-11 ⋅ 阅读:(28) ⋅ 点赞:(0)

《VBA之Word应用》(版权10178982),是我推出第八套教程,教程是专门讲解VBA在Word中的应用,围绕“面向对象编程”讲解,首先让大家认识Word中VBA的对象,以及对象的属性、方法,然后通过实例让大家感受到Word VBA 的妙处。

这套教程是专门针对WORD VBA 的教程,是VBA中的稀缺资源,我给这套教程分归为中级教程,希望大家在VBA入门后再学习这套教程,这样会更加深入的理解面向对象编程的意义。

本套教程共三册十六章,今日内容为第二章部分:VBA之Word应用第二章第八节:批量替换模板中固定字段的内容并另存为新文件e7cb8d53f18b99b2b05d1f02c0a3a5fe.jpeg

分享成果,随喜正能量】 你真正要做的事情,连神明都不要讲。安静地做,成功了再说。事以密成,言以泄败,隐忍且蓄势待发。潜龙勿用,才能见龙在天而当。。

第八节 批量替换模板中固定字段的内容并另存为新文件

大家好,我们今日讲解书签内容的最后一讲,这讲的内容是第五节内容的引申,也是Word文档中最为常见的一种批量处理替换文档中固定字段的方案。希望大家能仔细学习并掌握。

1 批量替换文档中固定字段的场景及思路分析

我们在平时Word操作中,最为常见的一种操作是批量替换模板中的固定字段,并形成一个新文件保存下来.如下面的模板截图:

79748b90779a1011eaea3841d12dba0d.jpeg

这是我的一份《VBA初级阶段自测题》的文档,要按照学员姓名的不同,修改文档中的姓名、年龄、籍贯后分成不同的文档并分别保存,最后形成若干个不同的文档。当然,在实际的工作中,不一定是这份自测题的文档,或许是一份抗击疫情的表格,或者是一份调查问卷,或者是一份通知的下发文档等等。这种场景在实际工作中利用还是非常多的。如果是手工操作,需要单个打开模板文件,修改上述的固定字段后,然后保存,这种操作单纯是一种重复的操作,没有技术含量,但往往不能出错。

我们知道,对于这类数据处理,VBA是强项。利用VBA来处理这类应用,是最为方便的,可以根据自己的需要随时调整代码的框架。

那么,利用VBA如何来完成批量替换文档中固定字段呢?下面我们看一下思路的分析:

1)在模板文件中需要替换的固定字段处插入不同的书签。

2)利用VBA代码检测模板中的书签,将光标置于第一个书签处,并将选定内容扩展到书签所在行的末尾。

3)将选定的范围进行替换

4)重复上面的2)动作,不过这次是将光标置于第二个书签处,并将选定内容扩展到书签所在行的末尾。

5)将选定范围进行替换。

6)重复上面的2)动作,不过这次是将光标置于第三个书签处,并将选定内容扩展到书签所在行的末尾。

5)将选定范围进行替换。

通过上面的操作完成了我们第一个文档,另存为一个新的文件即可。

2 批量替换文档中固定字段的代码

下面我们先看一下我给出的代码:

Sub mynzI() '批量修改文档的内容

Dim A(3)

Dim myDoc As Document

Dim TEM As String

A(1) = Array("李冰冰", "23", "丹麦")

A(2) = Array("赵冰冰", "25", "唐山")

A(3) = Array("白冰冰", "24", "湖北")

For t = 1 To 3

Set myDoc = Documents.Open(ActiveDocument.Path & "\示例02.docx")

For I = 1 To 3

Selection.GoTo What:=wdGoToBookmark, Name:="C00" & I

Selection.EndKey Unit:=wdLine, Extend:=wdExtend

UU = A(t)

TEM = UU(I - 1)

Selection.Text = TEM & vbCr

Next

ActiveDocument.SaveAs2 UU(0) & "自测题"

ActiveDocument.Close (True)

Next

End Sub

代码截图:

652a5f3436ecb6e73bc254e7846fd136.jpeg

3 批量替换文档中固定字段代码的讲解及测试效果

为了完成我们的测试,我们先要在模板中的固定字段位置插入书签,具体的操作在前面的章节中已经详细地介绍,插入的书签如下面的截图:

39ad83b6ebcee006ac50c79ed13f8117.jpeg

我们先来看看代码的讲解:

1)Dim A(3) 定义一个一维数组,我没有给出数组的类型,说明是一个Variant。

2) A(1) = Array("李冰冰", "23", "丹麦")

A(2) = Array("赵冰冰", "25", "唐山")

A(3) = Array("白冰冰", "24", "湖北")

以上是我们定义的数组三个元素,每个元素还是数组。外层的数组是我们将要形成的三个文件,内层数组是每个文件中要替换的每个字段。

3) For t = 1 To 3

Set myDoc = Documents.Open(ActiveDocument.Path & "\示例02.docx")

’内层循环(同4))

ActiveDocument.SaveAs2 UU(0) & "自测题"

ActiveDocument.Close (True)

Next

上面的代码建立第一层循环,这层循环中首先会打开模板文件,在内层循环中进行处理后,最后另存为一个新的命名的文件,并关闭。

4) For I = 1 To 3

Selection.GoTo What:=wdGoToBookmark, Name:="C00" & I

Selection.EndKey Unit:=wdLine, Extend:=wdExtend

UU = A(t)

TEM = UU(I - 1)

Selection.Text = TEM & vbCr

Next

这是一个内层的循环,在内层的循环的,我们首先将光标转跳到Name:="C00" & I处;

然后将选择范围扩展到整行的最末尾(Selection.EndKey Unit:=wdLine, Extend:=wdExtend是将选择范围以行为单位扩展到的行的末尾);TEM = UU(I - 1) 是提取数组的元素; Selection.Text = TEM & vbCr是替换刚才所选中的内容,vbCr是换行符。

代码的测试效果:

运行后,会根据模板文件(“实例02”文件),形成三个独立的文件,如红色框的文件。

1772a485831338536f146cee015c3829.jpeg

我们打开其中的一个文件查看一下内容:

fb793be997cdab6f02247509e1b0a27a.jpeg

从以上的结果可以看出,完成了我们最初的要求。

今日内容回向:

1 批量修改文档中固定字段的思路是什么?

2 在批量修改文档中固定字段的代码中应用了两重循环,各自的目的是什么?

本讲内容参考程序文件:Doc 002文档.docm

分享成果,随喜正能量

9ababd0d1f600154cac762eaf94b219d.jpeg

我20多年的VBA实践经验,全部浓缩在下面的各个教程及应用工具中:

53e3c6b0d266103bf378e3a795c820bb.jpeg