ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 4641|回复: 10

谁能修改这个VBA

[复制链接]

TA的精华主题

TA的得分主题

发表于 2008-7-18 10:10 | 显示全部楼层 |阅读模式

这个宏是论谈上一位高手发表的,是用于同一目录下的多个EXCEL文件的工作簿到新表的,但它会将每个文件的所有工作簿都提取出来,我只想提取每个文件的第一个工作表,请问该如何修改,我是个新手,看不明其内部含义,请哪位高手帮助一下,谢谢!

Sub 合并工作簿()
    Dim FilesToOpen
    Dim x As Integer

    On Error GoTo ErrHandler
    Application.ScreenUpdating = False

    FilesToOpen = Application.GetOpenFilename _
      (FileFilter:="Microsoft Excel Files (*.xls), *.xls", _
      MultiSelect:=True, Title:="Files to Merge")

    If TypeName(FilesToOpen) = "Boolean" Then
        MsgBox "No Files were selected"
        GoTo ExitHandler
    End If

    x = 1
    While x <= UBound(FilesToOpen)
        Workbooks.Open Filename:=FilesToOpen(x)
        Sheets().Move After:=ThisWorkbook.Sheets _
          (ThisWorkbook.Sheets.Count)
        x = x + 1
    Wend

ExitHandler:
    Application.ScreenUpdating = True
    Exit Sub

ErrHandler:
    MsgBox Err.Description
    Resume ExitHandler
End Sub

TA的精华主题

TA的得分主题

发表于 2008-7-18 10:29 | 显示全部楼层

回复:(tanghong168)谁能修改这个VBA

Sub 合并工作簿()
    Dim FilesToOpen
    Dim x As Integer

    On Error GoTo ErrHandler
    Application.ScreenUpdating = False

    FilesToOpen = Application.GetOpenFilename _
      (FileFilter:="Microsoft Excel Files (*.xls), *.xls", _
      MultiSelect:=True, Title:="Files to Merge")

    If TypeName(FilesToOpen) = "Boolean" Then
        MsgBox "No Files were selected"
        GoTo ExitHandler
    End If

    x = 1
    While x <= UBound(FilesToOpen)
        Workbooks.Open Filename:=FilesToOpen(x)
        Sheets(1).Move After:=ThisWorkbook.Sheets _
          (ThisWorkbook.Sheets.Count)
        x = x + 1
    Wend

ExitHandler:
    Application.ScreenUpdating = True
    Exit Sub

ErrHandler:
    MsgBox Err.Description
    Resume ExitHandler
End Sub
如果要保持原文件的完整性, Sheets(1).Move After应该为:Sheets(1).Copy After

[此贴子已经被作者于2008-7-18 10:34:41编辑过]

TA的精华主题

TA的得分主题

发表于 2009-6-17 09:11 | 显示全部楼层
二楼,你好
你用的代码能合并工作簿,但能否将合并后的工作簿中的工作表名用原来的工作簿名呢?

TA的精华主题

TA的得分主题

发表于 2009-6-17 11:03 | 显示全部楼层

回复 3楼 yc2007 的帖子

Sub 合并工作簿()
    Dim FilesToOpen, wb As Workbook
    Dim x As Integer

    On Error GoTo ErrHandler
    Application.ScreenUpdating = False

    FilesToOpen = Application.GetOpenFilename _
      (FileFilter:="Microsoft Excel Files (*.xls), *.xls", _
      MultiSelect:=True, Title:="Files to Merge")

    If TypeName(FilesToOpen) = "Boolean" Then
        MsgBox "No Files were selected"
        GoTo ExitHandler
    End If

    x = 1
    While x <= UBound(FilesToOpen)
        If FilesToOpen(x) <> ThisWorkbook.FullName Then
            Set wb = Workbooks.Open(Filename:=FilesToOpen(x))
            wb.Sheets(1).Copy After:=ThisWorkbook.Sheets(ThisWorkbook.Sheets.Count)
            ActiveSheet.Name = Split(Split(FilesToOpen(x), "\")(UBound(Split(FilesToOpen(x), "\"))), ".")(0)
            wb.Close
        End If
        x = x + 1
    Wend

ExitHandler:
    Application.ScreenUpdating = True
    Exit Sub

ErrHandler:
    MsgBox Err.Description
    Resume ExitHandler
End Sub

TA的精华主题

TA的得分主题

发表于 2009-6-17 11:11 | 显示全部楼层
再提一个问题,就是每个工作簿中现在只有一个表的合并现在可以了.能否将多个工作簿中的多工作表合并到一个工作簿中,且在新工作簿中的工作表仍用原工作表的表名

TA的精华主题

TA的得分主题

发表于 2009-6-17 17:07 | 显示全部楼层

回复 5楼 yc2007 的帖子

Sub 合并工作簿()
    Dim FilesToOpen, wb As Workbook, sht As Worksheet
    Dim x As Integer

    On Error GoTo ErrHandler
    Application.ScreenUpdating = False

    FilesToOpen = Application.GetOpenFilename _
      (FileFilter:="Microsoft Excel Files (*.xls), *.xls", _
      MultiSelect:=True, Title:="Files to Merge")

    If TypeName(FilesToOpen) = "Boolean" Then
        MsgBox "No Files were selected"
        GoTo ExitHandler
    End If

    x = 1
    While x <= UBound(FilesToOpen)
        If FilesToOpen(x) <> ThisWorkbook.FullName Then
            Set wb = Workbooks.Open(Filename:=FilesToOpen(x))
            For Each sht In wb.Sheets
                sht.Copy After:=ThisWorkbook.Sheets(ThisWorkbook.Sheets.Count)
            Next
            wb.Close
        End If
        x = x + 1
    Wend

ExitHandler:
    Application.ScreenUpdating = True
    Exit Sub

ErrHandler:
    MsgBox Err.Description
    Resume ExitHandler
End Sub

TA的精华主题

TA的得分主题

发表于 2009-6-17 17:29 | 显示全部楼层
谢谢六楼,正是我想要的效果

TA的精华主题

TA的得分主题

发表于 2010-3-1 15:43 | 显示全部楼层
各工作簿的第一个工作表的结构相同,可否只合并第一个工作表到汇总工作表的一张工作表中。暂不考虑合并在一起的先后顺序!代码怎么写?

TA的精华主题

TA的得分主题

发表于 2010-3-1 16:53 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
原帖由 liuxiao 于 2010-3-1 15:43 发表
各工作簿的第一个工作表的结构相同,可否只合并第一个工作表到汇总工作表的一张工作表中。暂不考虑合并在一起的先后顺序!代码怎么写?

请参考:
Sub 合并工作簿()
    Dim FilesToOpen, sh As Worksheet
    Dim i&, m&

    On Error GoTo ErrHandler

    FilesToOpen = Application.GetOpenFilename _
      (FileFilter:="Microsoft Excel Files (*.xls), *.xls", _
      MultiSelect:=True, Title:="Files to Merge")

    If TypeName(FilesToOpen) = "Boolean" Then
        MsgBox "No Files were selected"
        GoTo ExitHandler
    End If
   
    Set sh = ActiveSheet
   
    Application.ScreenUpdating = False
    sh.UsedRange.Clear
    For i = 1 To UBound(FilesToOpen)
        If FilesToOpen(i) <> ThisWorkbook.FullName Then
            With GetObject(FilesToOpen(i))
                If .Sheets(1).UsedRange.Count > 1 Then
                     m = m + 1
                     If m = 1 Then
                        .Sheets(1).UsedRange.Copy sh.Range("a1")
                     Else
                        .Sheets(1).UsedRange.Copy sh.Range("a65536").End(xlUp).Offset(1)
                    End If
                End If
                .Close
            End With
        End If
    Next

ExitHandler:
    Application.ScreenUpdating = True
    Exit Sub

ErrHandler:
    MsgBox Err.Description
    Resume ExitHandler
End Sub

TA的精华主题

TA的得分主题

发表于 2010-3-1 21:29 | 显示全部楼层
原帖由 zhaogang1960 于 2010-3-1 16:53 发表

请参考:
Sub 合并工作簿()
    Dim FilesToOpen, sh As Worksheet
    Dim i&, m&

    On Error GoTo ErrHandler

    FilesToOpen = Application.GetOpenFilename _
      (FileFilter:="Microsoft Exc ...

代码经测试,只是起到导入一个工作簿的工作表的作用,没有能起到汇总作用。我想实现的是汇总各工作表除表头以外的内容,连续依次按行记录!
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-27 19:40 , Processed in 0.045635 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

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