| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 4659 人关注过本帖
标题:合并同一个文件夹中多个相同结构的EXCEL表合并在一个EXCEL表中代码不明白, ...
只看楼主 加入收藏
sylknb
Rank: 4
等 级:贵宾
威 望:14
帖 子:1526
专家分:177
注 册:2006-6-3
结帖率:79.38%
收藏
已结贴  问题点数:20 回复次数:4 
合并同一个文件夹中多个相同结构的EXCEL表合并在一个EXCEL表中代码不明白,请高手指教
下面的合并代码。VBA我是新手不懂,哪位高手能否逐行注释一下好吗?多谢了

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

Num = 0

Do While MyName <> ""

If MyName <> AWbName Then  
Set Wb = Workbooks.Open(MyPath & "\" & MyName)

Num = Num + 1

With Workbooks(1).ActiveSheet

.Cells(.Range("B65536").End(xlUp).Row +2, 1) = Left(MyName, Len(MyName) - 4)

For G = 1 To Sheets.Count

Wb.Sheets(G).UsedRange.Copy .Cells(.Range("B65536").End(xlUp).Row + 1, 1)  
Next

WbN = WbN & Chr(13) & Wb.Name

Wb.Close False

End With

End If

MyName = Dir

Loop

Range("A1").Select

Application.ScreenUpdating = True

MsgBox "共合并了" & Num & "个工作薄下的全部工作表。如下:" & Chr(13) & WbN, vbInformation, "提示"

End Sub
搜索更多相关主题的帖子: 文件夹 工作表 EXCEL 
2016-11-27 14:10
xiangyue0510
Rank: 14Rank: 14Rank: 14Rank: 14
等 级:贵宾
威 望:86
帖 子:938
专家分:5244
注 册:2015-8-10
收藏
得分:20 
学习VB或者VBA的过程就是学习别人的代码,并转为己用。如果你连这个过程都想要假借别人之手,我认为你不需要学习VB了
2016-11-27 15:14
sylknb
Rank: 4
等 级:贵宾
威 望:14
帖 子:1526
专家分:177
注 册:2006-6-3
收藏
得分:0 
班主:
不懂才向人请教。
2016-11-27 20:28
xiangyue0510
Rank: 14Rank: 14Rank: 14Rank: 14
等 级:贵宾
威 望:86
帖 子:938
专家分:5244
注 册:2015-8-10
收藏
得分:0 
你可以说哪一句不明白来问,每一句都要别人给你标注,这个不是学习。
懒还如此的理直气壮,无语
2016-11-27 22:06
sylknb
Rank: 4
等 级:贵宾
威 望:14
帖 子:1526
专家分:177
注 册:2006-6-3
收藏
得分:0 
标有红色的代码能否解释好吗?

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

Num = 0

Do While MyName <> ""

If MyName <> AWbName Then  
Set Wb = Workbooks.Open(MyPath & "\" & MyName
)

Num = Num + 1

With Workbooks(1).ActiveSheet

.Cells(.Range("B65536").End(xlUp).Row +2, 1) = Left(MyName, Len(MyName) - 4)

For G = 1 To Sheets.Count

Wb.Sheets(G).UsedRange.Copy .Cells(.Range("B65536").End(xlUp).Row + 1, 1)  
Next

WbN = WbN & Chr(13) & Wb.Name

Wb.Close False

End With

End If

MyName = Dir

Loop

Range("A1").Select

Application.ScreenUpdating = True

MsgBox "共合并了" & Num & "个工作薄下的全部工作表。如下:" & Chr(13) & WbN, vbInformation, "提示"

End Sub
2016-11-29 09:32
快速回复:合并同一个文件夹中多个相同结构的EXCEL表合并在一个EXCEL表中代码不明 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017292 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved