利用VBA将数据区域不定的多个工作表数据快速合并到一个工作表方法 。有需要的朋友可以跟着教程一起来学习!
方法/步骤
分别有工作表1、2、3数据区域如下图所示:
按ALT+F11打开VBE编辑器 , 在工程窗口下的Microsoft Excel对象右键-插入-模块 , 新建一个模块1 。
输入如下代码:
【excel跨表格提取数据? 如何利用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
按ALT+F8打开宏对话框窗口 , 鼠标单击执行hbgzb宏 。
实现如图所示效果:
注意事项
本段VBA代码由于将编辑过的区域作为源数据区域 , 顾无论该数据源有无数据 , 只要曾经编辑过皆做为源数据源 , 做拷贝处理 。
以上就是利用VBA将excel多个工作表数据快速合并到一个工作表方法介绍 , 希望能对大家有所帮助!
推荐阅读
- 如何取消表格美化功能? Excel 2016图表美化4个技巧
- excel导入另一个表数据? Excel多表数据出错怎么办
- 丧假包含双休日和法定节假日吗
- 表格里面的超链接求和? Excel怎么使用超链接函数HYPERLINK
- 对公司的意见,对公司的意见和建议有哪些
- excel两行字之间的间距? excel怎么设置行距
- excel图表数据标签显示值? excel怎么设置总显示一行数据
- “三个以案”警示教育内容是什么 《以案为鉴》警示教育心得体会
- 鞋放在阳台上可以吗