多个select count 合并_Excel | VBA帮你合并工作薄或工作表,收藏备用

合并工作簿与合并工作表,是Excel数据处理永恒的话题。原来韩老师讲过用SQL语句,还讲过Excel|零基础也会合并多工作表,只需鼠标按序点下去,今天给大家两组代码,每次需要合并工作簿与或是工作表时,复制过来使用就好了。

合并工作簿

代码如下(代码横屏观看效果更好):

Sub 合并工作薄()Dim FileOpen          '定义打开文件变量Dim i As Integer      '定义打开文件个数变量Application.ScreenUpdating = False       '关闭屏幕更新,避免合并时屏幕闪烁FileOpen = Application.GetOpenFilename(FileFilter:="Microsoft Excel文件(.xlsx),.xlsx", MultiSelect:=True)  '打开文件类型为.xlsx,并可以打开多个i = 1Do While i <= UBound(FileOpen)    Workbooks.Open Filename:=FileOpen(i)Sheets().Move After:=ThisWorkbook.Sheets(ThisWorkbook.Sheets.Count)           '将需要合并的工作薄中工作表合并到最后一个工作表    i = i + 1LoopApplication.ScreenUpdating = True     '打开屏幕更新MsgBox "已完成合并"                   '合并完成并提示End Sub

代码窗口如下:

5053624afa0abef4da6fde85e99b2f00.png

效果如下:

b1e25d14cfe562d722e0f00c280a0aac.gif

合并工作表

在VBA窗口中输入以下代码(代码横屏观看效果更好):

Sub 合并工作表()Application.ScreenUpdating = False   '关闭屏幕更新,避免合并时屏幕闪烁Dim sht As Worksheet                 '定义工作表变量Dim irow%, icol%                     '定义行列变量Sheet1.UsedRange.ClearContents       '清除sheet1现有数据For Each sht In Worksheets    If sht.Name <> Sheet1.Name Then        With sht            irow = .Cells(.Rows.Count, 1).End(xlUp).Row                  '当前工作表数据行数            icol = .Cells(1, .Columns.Count).End(xlToLeft).Column        '当前工作表数据列数            If Sheet1.Range("a1") = "" Then                .Range("a1").Resize(irow, icol).Copy Sheet1.Range("a1")  '当前工作表第一行复制到汇总工作表            Else                .Range("a2").Resize(irow - 1, icol).Copy Sheet1.Range("a" & Sheet1.Cells(Sheet1.Rows.Count, 1).End(xlUp).Row + 1)  '当前工作表除第一行以外的数据复制到汇总工作表            End If        End With    End IfNextApplication.ScreenUpdating = True     '打开屏幕更新End Sub

如下图:

8a8549e7e72e69ec1a4548285323027e.png

效果如下:

5aa6140db662e96781a288215f89e5e3.gif

不要怕VBA,你可以从模仿开始写起的,写多了,见识多了,你也会了。当然,如果有编辑的基础的,学的快一些,如果没有编辑基础的朋友,那要先去了解变量、语句、算法、对象的概念了。

------------------------------------------

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值