搜索
查看: 2312|回复: 0

解析拷贝路径下所有Excel到一个工作表下的示例

[复制链接]

978

主题

1094

帖子

1万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
15950
发表于 2018-12-20 08:54:14 | 显示全部楼层 |阅读模式
Sub 合并当前目录下所有工作簿的全部工作表()  #模块名称
Dim MyPath, MyName, AWbName                          #变量声明
Dim Wb As workbook, WbN As String
Dim G As Long
Dim Num As Long
Dim BOX As String
Application.ScreenUpdating = False                        #停止屏幕刷新
MyPath = ActiveWorkbook.Path                                #获取当前工作文件路径
MyName = Dir(MyPath & "\" & "*.xls")                #获取当前文件名(截取字符串)
AWbName = ActiveWorkbook.Name                        #获取当前BookName
Num = 0                                                                #准备进入循环处理
Do While MyName <> ""                                        #第一个循环体:遍历所有文件 终止条件是 文件名为空
If MyName <> AWbName Then                                #条件:文件名当前激活文件不同
Set Wb = Workbooks.Open(MyPath & "\" & MyName)                # 设置工作表的名称(当前Sheet Name)
Num = Num + 1                                                #计数用于输出
With Workbooks(1).ActiveSheet
.Cells(.Range("B65536").End(xlUp).Row + 2, 1) = Left(MyName, Len(MyName) - 4)
#赋值语句:激活Sheet的A列最后一个单元格赋值为MyName去掉‘.xls’的部分
#Left 截取字符串 去掉了'.xls'
#workbooks(n) 为取工作簿 的写法
#A65535(一个极大数)单元格向上,最后一个非空的单元格的行号
For G = 1 To Sheets.Count                                        #嵌套循环体:遍历文件的所有Sheets
Wb.Sheets(G).UsedRange.Copy .Cells(.Range("B65536").End(xlUp).Row + 1, 1)       
          #赋值所有内容到以结束内容空一行开始的表格中
Next                                                                        #且套循环体结束                                                       
WbN = WbN & Chr(13) & Wb.Name                        # & 为合并字符串的符号               
Wb.Close False                                                        #对于文件操作结束,关闭Excel文件
End With                                                                #退出第二个判断
End If                                                                #退出第一个判断
MyName = Dir                                                         #怎么拿到第二个bookName
Loop                                                                        #循环体结束
Range("B1").Select                                                #选中B1
Application.ScreenUpdating = True                        #允许Excel屏幕刷新
MsgBox "共合并了" & Num & "个工作薄下的全部工作表。如下:" & Chr(13) & WbN, vbInformation, "提示"
End Sub
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

表格智创网

网站简介:表格智创网,是一家以表格设计和技能分享的专业社区,由会计帮帮网投资建设,尽专业,助提高专业技能。

表格智创网欢迎您!

联系我们

  • 工作时间:早上9:00-16:00
  • 客服电话:18668755857
  • 本站网址:www.excelwps.com
  • 淘宝店址:kjbbw.taobao.com

Powered by Discuz! X3.4 © 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表