计算机教程网

您现在的位置是:首页 > 办公软件教程 > Excel教程

Excel教程

如何利用VBA将excel多个工作表数据快速合并到一个工作表上

2024-05-23 23:04:26Excel教程 卡饭网 梦在深巷
如何利用VBA将excel多个工作表数据快速合并到一个工作表上 利用VBA将数据区域不定的多个工作表数据快速合并到一个工作表方法.有需要的朋友可以跟着教程一起来学习! 方法/步骤 分别有工作表1.2.3数据区域如下图所示: 按ALT+F11打开VBE编辑器,在工程窗口下的Microsoft Excel对象右键-插入-模块,新建一个模块1. 输入如下代码: 复制代码 代码如下: Option Explicit Sub hbgzb() Dim sh As Worksheet, flag As Boolean,

利用VBA将数据区域不定的多个工作表数据快速合并到一个工作表方法。有需要的朋友可以跟着教程一起来学习!

方法/步骤

分别有工作表1、2、3数据区域如下图所示:

如何利用VBA将excel多个工作表数据快速合并到一个工作表上

如何利用VBA将excel多个工作表数据快速合并到一个工作表上

如何利用VBA将excel多个工作表数据快速合并到一个工作表上

按ALT+F11打开VBE编辑器,在工程窗口下的Microsoft Excel对象右键-插入-模块,新建一个模块1。

如何利用VBA将excel多个工作表数据快速合并到一个工作表上

输入如下代码:

复制代码
代码如下:
Option Explicit
Sub hbgzb()
Dim sh As Worksheet, flag As Boolean, i As Integer, hrow As Integer, hrowc As Integer
flag = False
For i = 1 To Sheets.Count
If Sheets(i).Name = "合并数据" Then flag = True
Next
If flag = False Then
Set sh = Worksheets.Add
sh.Name = "合并数据"
Sheets("合并数据").Move after:=Sheets(Sheets.Count)
End If
For i = 1 To Sheets.Count
If Sheets(i).Name <> "合并数据" Then
hrow = Sheets("合并数据").UsedRange.Row
hrowc = Sheets("合并数据").UsedRange.Rows.Count
If hrowc = 1 Then
Sheets(i).UsedRange.Copy Sheets("合并数据").Cells(hrow, 1).End(xlUp)
Else
Sheets(i).UsedRange.Copy Sheets("合并数据").Cells(hrow + hrowc - 1, 1).Offset(1, 0)
End If
End If
Next i
End Sub

如何利用VBA将excel多个工作表数据快速合并到一个工作表上

按ALT+F8打开宏对话框窗口,鼠标单击执行hbgzb宏。

如何利用VBA将excel多个工作表数据快速合并到一个工作表上

实现如图所示效果:

如何利用VBA将excel多个工作表数据快速合并到一个工作表上

注意事项

本段VBA代码由于将编辑过的区域作为源数据区域,顾无论该数据源有无数据,只要曾经编辑过皆做为源数据源,做拷贝处理。

以上就是利用VBA将excel多个工作表数据快速合并到一个工作表方法介绍,希望能对大家有所帮助!