0

0

Excel如何使用VBA自动将多个工作表合并成一个_Excel VBA工作表合并教程

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-11-23 18:37:23

|

377人浏览过

|

来源于php中文网

原创

使用VBA可高效合并多个工作表数据。首先通过Alt+F11打开编辑器,插入模块并粘贴代码,实现三种合并方式:一是循环合并所有工作表内容至“汇总”表;二是仅合并非法指定名称的特定工作表(如销售表、库存表、订单表);三是合并时跳过除首个工作表外的标题行,避免重复。每种方法均自动创建或清空“汇总”表,逐行复制数据并提示完成,确保操作快速准确。

excel如何使用vba自动将多个工作表合并成一个_excel vba工作表合并教程

如果您需要将多个工作表中的数据整合到一个汇总表中,手动复制粘贴不仅耗时还容易出错。通过使用VBA可以实现快速、准确地合并多个工作表的数据。以下是实现该功能的具体步骤:

本文运行环境:Dell XPS 13,Windows 11

一、使用VBA循环合并所有工作表

该方法适用于将当前工作簿中所有工作表的数据(除目标汇总表外)逐行复制到一个新的工作表中,保留原始数据结构。

1、按下 Alt + F11 打开VBA编辑器。

2、在左侧工程资源管理器中右键点击当前工作簿名称,选择“插入” -> “模块”。

3、将以下代码粘贴到代码窗口中:

Sub 合并所有工作表()
Dim ws As Worksheet
Dim targetSheet As Worksheet
Dim nextRow As Long
Application.ScreenUpdating = False
On Error Resume Next
Set targetSheet = ThisWorkbook.Sheets("汇总")
If targetSheet Is Nothing Then
Set targetSheet = ThisWorkbook.Sheets.Add
targetSheet.Name = "汇总"
Else
targetSheet.Cells.Clear
End If
nextRow = 1
For Each ws In ThisWorkbook.Sheets
If ws.Name targetSheet.Name Then
If ws.UsedRange.Rows.Count > 0 Then
ws.UsedRange.Copy Destination:=targetSheet.Cells(nextRow, 1)
nextRow = nextRow + ws.UsedRange.Rows.Count
End If
End If
Next ws
Application.ScreenUpdating = True
MsgBox "合并完成!"
End Sub

4、关闭VBA编辑器,返回Excel,按下 Alt + F8,选择“合并所有工作表”,点击“运行”即可执行合并。

二、仅合并指定名称的工作表

当只需要合并部分特定名称的工作表时,可通过定义工作表名称数组来精确控制哪些表参与合并。

1、打开VBA编辑器,插入新模块或使用已有模块。

万兴爱画
万兴爱画

万兴爱画AI绘画生成工具

下载

2、输入以下代码:

Sub 合并非法合并指定表()
Dim sheetNames As Variant
Dim wsName As Variant
Dim ws As Worksheet
Dim targetSheet As Worksheet
Dim nextRow As Long
sheetNames = Array("销售表", "库存表", "订单表") ' 修改为实际需要的表名
Application.ScreenUpdating = False
On Error Resume Next
Set targetSheet = ThisWorkbook.Sheets("汇总")
If targetSheet Is Nothing Then
Set targetSheet = ThisWorkbook.Sheets.Add
targetSheet.Name = "汇总"
End If
targetSheet.Cells.Clear
nextRow = 1
For Each wsName In sheetNames
Set ws = Nothing
Set ws = ThisWorkbook.Sheets(wsName)
If Not ws Is Nothing Then
If ws.UsedRange.Rows.Count > 0 Then
ws.UsedRange.Copy Destination:=targetSheet.Cells(nextRow, 1)
nextRow = nextRow + ws.UsedRange.Rows.Count
End If
End If
Next wsName
Application.ScreenUpdating = True
MsgBox "指定工作表合并完成!"
End Sub

3、根据实际需求修改 Array("销售表", "库存表", "订单表") 中的名称。

4、运行宏即可完成指定工作表的合并。

三、合并时跳过标题行重复项

此方法用于避免在合并过程中重复粘贴每个工作表的标题行,仅保留第一个工作表的标题。

1、在VBA编辑器中创建新模块或复用现有模块。

2、输入以下代码:

Sub 合并去重标题()
Dim ws As Worksheet
Dim targetSheet As Worksheet
Dim nextRow As Long
Dim isFirstSheet As Boolean
Application.ScreenUpdating = False
On Error Resume Next
Set targetSheet = ThisWorkbook.Sheets("汇总")
If targetSheet Is Nothing Then
Set targetSheet = ThisWorkbook.Sheets.Add
targetSheet.Name = "汇总"
End If
targetSheet.Cells.Clear
nextRow = 1
isFirstSheet = True
For Each ws In ThisWorkbook.Sheets
If ws.Name targetSheet.Name Then
If ws.UsedRange.Rows.Count > 0 Then
If isFirstSheet Then
ws.UsedRange.Copy targetSheet.Cells(nextRow, 1)
nextRow = nextRow + ws.UsedRange.Rows.Count
isFirstSheet = False
Else
ws.Range(ws.UsedRange.Rows(1).Offset(1).Address & ":" & ws.UsedRange.Rows(ws.UsedRange.Rows.Count).Address).Copy _
Destination:=targetSheet.Cells(nextRow, 1)
nextRow = nextRow + ws.UsedRange.Rows.Count - 1
End If
End If
End If
Next ws
Application.ScreenUpdating = True
MsgBox "已合并且去除重复标题!"
End Sub

3、运行该宏后,除第一个工作表外,其余工作表将从第二行开始复制数据,从而避免标题重复。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java中boolean的用法
java中boolean的用法

在Java中,boolean是一种基本数据类型,它只有两个可能的值:true和false。boolean类型经常用于条件测试,比如进行比较或者检查某个条件是否满足。想了解更多java中boolean的相关内容,可以阅读本专题下面的文章。

351

2023.11.13

java boolean类型
java boolean类型

本专题整合了java中boolean类型相关教程,阅读专题下面的文章了解更多详细内容。

32

2025.11.30

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

780

2023.08.22

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

198

2023.11.20

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

228

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

297

2023.10.25

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

539

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

21

2025.12.22

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

php-src源码分析探索
php-src源码分析探索

共6课时 | 0.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号