合并具有文本框的Word文档:VBA代码批量操作

news/2024/11/16 15:58:58/文章来源:https://www.cnblogs.com/fkxxgis/p/18549418

  本文介绍基于VBA语言,对大量含有图片、文本框与表格的Word文档加以批量自动合并,并在每一次合并时添加分页符的方法。

  在我们之前的文章中,介绍过基于Python语言的python-docxdocx)模块与docxcompose模块,对大量Word文档加以合并的方法;但是,基于这种方法,我们无法对具有非明确大小的文本框Word加以合并,因为python-docx无法处理含有这种元素的Word文件。最近,一位老哥提出了合并含有文本框Word的需求,所以就尝试用VBA来实现这一操作,这里就介绍一下具体的方法。

  其中,VBA是Visual Basic for Applications的缩写,其是基于Visual Basic语言的一种扩展,主要应用于微软Office套件中各种应用程序,例如WordExcelPowerPoint等;其允许用户创建自定义的宏和应用程序来自动执行各种任务,从而提高工作效率。目前,VBA主要就是应用于需要批量操作Office文件的各类场景中。

  本文的需求如下。现在有一个文件夹,其中包含大量文档文件,如下图所示;其中,每一个文档中,都包含图片、表格、文本框等较为复杂的元素

image

  我们现在希望,可以批量将文件夹中大量文档文件加以合并;并且在合并时,每次都需要在新的1页中合并下一个文件(也就是,不同文件的内容不要出现在1页中)。

  明确了需求,即可开始代码撰写。本文所需代码如下。

Sub merge_word()Dim time_start As Single: time_start = TimerDim word_result As DocumentDim word_temp As DocumentDim file_dialog As FileDialogDim str As StringDim fileDim num As LongSet word_result = ActiveDocumentSet file_dialog = Application.FileDialog(msoFileDialogFilePicker)With file_dialog.AllowMultiSelect = True.Title = "请选择【一个或多个】需要与当前文档合并的文件"With .Filters.Clear.Add "Word文件", "*.doc*;*.dot*;*.wps".Add "所有文件", "*.*"End WithIf .Show ThenApplication.ScreenUpdating = Falsenum = .SelectedItems.countFor Each file In .SelectedItemsSet word_temp = Documents.Open(file)word_temp.Range.Copyword_result.Range(word_result.Range.End - 1, word_result.Range.End).SelectDoEventsSelection.PasteSelection.InsertBreakword_temp.Close wdDoNotSaveChangesNextApplication.ScreenUpdating = TrueEnd IfEnd WithSet word_result = NothingSet word_temp = NothingSet file_dialog = Nothingstr = Format(Timer - time_start, "均已成功合并;共用时0秒!")str = Format(num, "您选择合并0个文件,") & strMsgBox str, vbInformation, "文件合并结果"
End Sub

  上述代码中,我们首先进行变量声明time_start是一个Single类型的变量,用以记录代码开始执行的时间;Timer函数返回一个单精度浮点数,表示从计算机启动到现在经过的秒数。word_result是一个Document类型的变量,用以存储当前打开的Word文档。word_temp是另一个Document类型的变量,用以临时存储要合并的其他Word文档。file_dialog是一个FileDialog类型的变量,用以存储文件选择对话框对象。str是一个字符串类型的变量,用以存储最终要显示在消息框中的合并结果信息。file用以在循环中存储用户选择的每个文件路径。num是一个长整型变量,用以存储用户选择的文件数量。

  随后,我们获取当前文档。将当前正在编辑的Word文档赋值给word_result变量,这个文档就是要合并其他文档内容的结果文档。

  接下来,我们打开文件选择对话框。创建一个文件选择对话框对象,并逐一设置对话框的属性;其中,允许用户选择多个文件,自定义对话框标题,并设置文件类型过滤器,其中第一个表示只显示Word文档文件,第二个则表示显示所有类型的文件。

  紧接着,通过If .Show Then语句,判断用户在对话框中是否选择了文件。如果是的话,执行合并操作。其中,首先获取用户选择的文件数量;随后,循环遍历每个选择的文件——打开每个选择的文件作为临时文档,将临时文档的全部内容复制到剪贴板;将光标定位到目标文档(也就是结果文件)的最后一个字符处,并将剪贴板中的内容粘贴到目标文档的末尾,同时在粘贴的内容后插入一个分页符;最后,关闭临时文档而不保存更改。接下来,进行下一次遍历。其中需要注意,这里如果我们不添加DoEvents这句代码,会导致其下方的Selection.Paste这句代码报错(虽然会报错,但其实选择调试后继续按下F5,程序也还是可以运行)。

  最后,即可清理变量引用,并计算合并操作的耗时,将结果信息显示在消息框中。

  代码的执行方法如下。首先,在任意路径创建一个空白的Word文档,作为我们的结果文件。随后,在这个文档中,同时按下Alt键与F11键,进入VBA宏界面,如下图所示。

  随后,在左上角的Normal处右键,选择“插入”→“模块”,如下图所示。

  随后,在弹出的窗口中,复制前述代码,如下图所示。

  接下来,按下F5键,即可开始运行代码。其中,首先弹出一个选择文件的窗口,我们选择待合并的文件即可;如下图所示。

  随后,点击“确定”,即可开始合并文件。稍等片刻,合并完成,并将弹出如下所示界面。

  此时,回到我们打开的Word文件中,即可看到文件已经被合并在内了。

  其中,上图中紫色框所示区域,就是我这里待合并文件的开头部分(紫色框内红色的两段线仅仅是为了遮挡文件中的部分信息,没有别的含义,大家理解即可)——可以看到,每一次新的文件合并时,都是在新的一页操作的,符合我们的需求。

  至此,大功告成。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/834641.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

streamstring类介绍

std::stringstream 是 C++ 标准库中提供的一个类,定义在头文件 <sstream> 中。它是基于字符串的流(stream),允许像操作输入流(std::cin)或输出流(std::cout)那样,操作字符串内容。 std::stringstream 是 std::iostream 的派生类,支持同时进行字符串解析(输入)…

爬虫

程序示例: import java.util.regex.Matcher; import java.util.regex.Pattern;public class RegexDemo6 {public static void main(String[] args) {/** 有如下文本, 请按照要求爬取数据. * Java 自从 95 年问世以来, 经历了很多版本, 目前企业中用的最多的是 Java8 和 Java11,…

将数值转换为字符串的函数

在 C++ 中,itoa 和 sprintf 是用于将数值转换为字符串的经典函数。然而,它们有一定的局限性或者安全性问题,现代 C++ 更倾向于使用标准库的解决方案,如 std::to_string 和 std::stringstream,来代替这些函数。 1. itoa 的替代 itoa 是一种将整数转换为字符串的函数,但它不…

20222406 2024-2025-1 《网络与系统攻防技术》实验五实验报告

20222406 2024-2025-1 《网络与系统攻防技术》实验五实验报告 1.实验内容对网站进行 DNS 域名查询,包括注册人、IP 地址等信息,还通过相关命令查询 IP 地址注册人及地理位置。尝试获取 QQ 好友 IP 地址并查询其地理位置。使用 nmap 对靶机环境扫描,获取靶机 IP 活跃状态、开…

delphi 新版内存表 FDMemTable

c++builder XE 官方demo最全60多个 http://community.embarcadero.com/blogs?view=entry&id=8761FireDAC.Comp.Client用好FDMemTable代替之前的ClientDataSet,以前ClientDataSet内存表转换太繁琐了步骤。TClientDataSet *cds = new TClientDataSet(this); DataSetProvid…

理想雪 - 翠鸟协会

写在前面3844 字 | 小说 | 热爱 | 思考 | 表达 | 坚定 | 证明 | 坚守《理想雪》系列故事均为架空世界观,所有人名、地名等与现实世界无任何关联。该系列只且仅只为了说明,小说作者在该情境下会诞生的想法和采取的行动,以及背后的世界观、价值观和人生观。因此将具有强烈的个…

专题课:综合案例5

评委打分解答: 1.首先肯定要键盘录入6个评委的分数6个评委的分数,即6个变量,我们肯定用数组更加方便,因为后面求和求最大值之类的,用数组都更简单 遍历数组,我们每键盘打出一个元素就将其放入数组中 . 2.然后定义求和变量,将6个分数求和3.for循环搭配if筛选求最大、最小…

# 20222403 2024-2025-1 《网络与系统攻防技术》实验六实验报告

1.实验内容 本实践目标是掌握metasploit的用法。 指导书参考Rapid7官网的指导教程。 https://docs.rapid7.com/metasploit/metasploitable-2-exploitability-guide/ 下载官方靶机Metasploitable2,完成下面实验内容。 (1)前期渗透 ①主机发现(可用Aux中的arp_sweep,search一…

_app搭建笔记

逍遥模拟器端口号:21503 (3)adb install +包名的绝对路径 安装apk包 案例:adb install E:\dcs\two\app\mojibase.apk E:\dcs\two\app\baiduyuedu_5520.apk (4)活动路径名: aapt d badging D:\app\baiduyuedu_3760.apk(5)adb uninstall 包名:卸载 com.baidu.yued…

20222323 2024-2025-1 《网络与系统攻防技术》实验六实验报告

1.实验内容 掌握metasploit的用法。 下载官方靶机Metasploitable2,完成下面实验内容。 (1)前期渗透 ①主机发现(可用Aux中的arp_sweep,search一下就可以use) ②端口扫描:可以直接用nmap,也可以用Aux中的portscan/tcp等。 ③选做:也可以扫系统版本、漏洞等。 (2)Vsft…

InDesign 2025 for Mac(Id2025)最新激活版20.0.0

InDesign 2025具备强大的功能和灵活的扩展性,支持插件扩展,用户可以根据自身需求自定义工具和工作流程。在处理复杂排版和多页面设计时,InDesign 2025注重用户界面的友好性与功能的直观性,即使是新手用户也能快速上手。 InDesign 2025增强了多模态图文编辑能力,使得图像与…

【跟着阿舜学音乐-笔记】1.12和弦功能与进行原理

七和弦 七和弦是三和弦的基础上叠加三音构成的和弦(四个音的和弦)。其中小大七和弦(CmM7)很少运用,因为调内没有小大七和弦,同时听感上也不是很好。 注:有另一种和弦命名方式,即三和弦与根音呈大小七度的音组成和弦的命名法,该命名法对比上述命名法有个特例——增大七…