首页 > 其他分享 >合并具有文本框的Word文档:VBA代码批量操作

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

时间:2024-11-16 15:45:24浏览次数:1  
标签:文件 VBA word 合并 文本框 文档 file Word

  本文介绍基于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 = Timer
    Dim word_result As Document
    Dim word_temp As Document
    Dim file_dialog As FileDialog
    Dim str As String
    Dim file
    Dim num As Long
    
    Set word_result = ActiveDocument
    Set file_dialog = Application.FileDialog(msoFileDialogFilePicker)
    
    With file_dialog
        .AllowMultiSelect = True
        .Title = "请选择【一个或多个】需要与当前文档合并的文件"
        With .Filters
            .Clear
            .Add "Word文件", "*.doc*;*.dot*;*.wps"
            .Add "所有文件", "*.*"
        End With
        If .Show Then
            Application.ScreenUpdating = False
            num = .SelectedItems.count
            For Each file In .SelectedItems
                Set word_temp = Documents.Open(file)
                word_temp.Range.Copy
                
                word_result.Range(word_result.Range.End - 1, word_result.Range.End).Select
                
                DoEvents
                Selection.Paste
                Selection.InsertBreak
                
                word_temp.Close wdDoNotSaveChanges
            Next
            
            Application.ScreenUpdating = True
        End If
    End With
    
    Set word_result = Nothing
    Set word_temp = Nothing
    Set file_dialog = Nothing
    
    str = Format(Timer - time_start, "均已成功合并;共用时0秒!")
    str = Format(num, "您选择合并0个文件,") & str
    MsgBox 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文件中,即可看到文件已经被合并在内了。

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

  至此,大功告成。

标签:文件,VBA,word,合并,文本框,文档,file,Word
From: https://www.cnblogs.com/fkxxgis/p/18549418

相关文章

  • VBA:聚光灯所有的技术都在这里了(纯干货,含vb.net)
     聚光灯效果         大多数人想要自己做聚光灯首先想到的是条件格式,条件格式有很多弊端,第一点对Excel的撤回功能有影响,第二点只对单个工作簿有作用,每次新的工作簿就没用了.第三点影响工作簿原有的格式.今天介绍两种完美聚光灯的方案VBA完美聚光灯原理:条件格......
  • 零基础入门Hadoop:IntelliJ IDEA远程连接服务器中Hadoop运行WordCount
    今天我们来聊一聊大数据,作为一个Hadoop的新手,我也并不敢深入探讨复杂的底层原理。因此,这篇文章的重点更多是从实际操作和入门实践的角度出发,带领大家一起了解大数据应用的基本过程。我们将通过一个经典的案例——WordCounter,来帮助大家入门。简单来说,这个案例的目标是从一个文本文......
  • Office Word 文档格式与目录样式(毕业设计论文常用)
     调整格式技巧:Word中点击“文件”--》"选项"--》“显示”,将高亮部分全部打钩,有利于查看格式字符、“分页符”和“分节符”两个很有用,其中分节符前后的页码是独立的。  样式间的关系:类比C++中类的继承编写的伪代码,“正文”为基类,派生出 “论文--正文”,论文--......
  • Python实现批量提取Word文档中的图片(支持.doc和.docx格式)
            在工作中,我们可能会遇到需要从多个Word文档中批量提取图片的需求。如果手动操作,效率低且容易出错。因此,利用Python自动化批量提取图片是一个不错的选择。本篇文章将详细介绍如何使用Python来实现从.doc和.docx格式的Word文档中批量提取图片并保存......
  • XHEDITOR编辑支持WORD内容和截图的复制黏贴
    编辑器:xhEditor前端:vue2,vue3,vue-cli,html5后端:asp,php,jsp,springboot,asp.net,.netcore功能:复制粘贴word内容图片,要求:免费,开源,技术支持最近搞定块挻火的,今天早上又有网友加我微信私聊,也是想了解这块的技术和方案。昨天晚上论坛里面的一个网友给我发私信,想了解一下......
  • 智慧园区建设项目可行性研究报告立项报告,智慧园区可行性研究报告,智慧园区综合信息管理
      一、智慧园区管理系统方案介绍二、智慧园区管理系统方案优点三、智慧园区管理系统方案功能四、智慧园区管理系统APP开发五、智慧园区管理系统方案特点六、智慧园区管理系统建设目标七、智慧园区管理系统总体建设方案八、智慧园区管......
  • 【固定资产系统】资产管理平台建设方案,RFID,资产盘点,资产折旧,耗材管理(Word原件)
    固定资产管理系统旨在实现全方位、数字化的资产管理。首先,我们希望通过这一系统,对全公司的日常办公用品、标准物质及常用物品等固定资产进行精细化的申购、入库和领用管理。从资产采购到报废维修,每一个环节都应被纳入数字化流程,以减少人工操作的繁琐,提升管理效率。其次,系统应......
  • word模板填充 java
    From: https://blog.51cto.com/u_16213356/12447686在现代开发中,Word文档的自动生成和模板填充是一项非常常见的需求。尤其是在生成报表、合同、信函等场景时,通过代码自动化填充模板可以极大提高工作效率。本文将详细介绍如何使用Java实现Word模板填充。我们将通过以下步骤......
  • 使用Java填充Word模板的方法详解
    From: https://www.jb51.net/program/324679hhw.htmJava填充Word模板是一种将动态数据插入到Word文档模板中生成最终文档的过程,通常用于批量创建包含个人信息、报告结果或其他动态内容的文档,本文给大家介绍了使用Java填充Word模板的方法,需要的朋友可以参考下 +目录概......
  • 深入浅出Word2Vec:从原理到实战,如何利用词嵌入提升NLP应用
    深入浅出Word2Vec:从原理到实战,如何利用词嵌入提升NLP应用引言:为什么Word2Vec如此重要?自然语言处理(NLP)作为人工智能中的核心领域,面临着如何将人类语言转化为机器可以理解的形式的问题。在这方面,Word2Vec模型作为一种强大的词嵌入方法,极大地推动了NLP技术的进步。通过将每个......