Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 1840|回复: 2

[已解决]优化合并指定工作簿VBA代码,代码只能指定xls文件,无法指定2007文件。

[复制链接]
发表于 2014-1-15 10:33 | 显示全部楼层 |阅读模式
本帖最后由 yang2739 于 2014-1-15 13:31 编辑

Sub 合并指定工作簿()
    Dim FilesToOpen
    Dim x As Integer
    On Error GoTo ErrHandler
    Application.ScreenUpdating = False
    FilesToOpen = Application.GetOpenFilename(FileFilter:="MicroSoft Excel文件(*.xls),*.xlsx", MultiSelect:=True, Title:="要合并的文件")
   
    If TypeName(FilesToOpen) = "Boolean" Then
        MsgBox "没有选中文件"
        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
最佳答案
2014-1-15 13:15
    FilesToOpen = Application.GetOpenFilename(FileFilter:="Excel 2003文件,*.xls,Excel 2007文件,*.xlsx,Excel 2007宏文件,*.xlsm", MultiSelect:=True, Title:="要合并的文件")
excel精英培训的微信平台,每天都会发送excel学习教程和资料。扫一扫明天就可以收到新教程
发表于 2014-1-15 13:07 | 显示全部楼层
FilesToOpen = Application.GetOpenFilename(FileFilter:="MicroSoft Excel文件,*.xls*", MultiSelect:=True, Title:="要合并的文件")
回复

使用道具 举报

发表于 2014-1-15 13:15 | 显示全部楼层    本楼为最佳答案   
    FilesToOpen = Application.GetOpenFilename(FileFilter:="Excel 2003文件,*.xls,Excel 2007文件,*.xlsx,Excel 2007宏文件,*.xlsm", MultiSelect:=True, Title:="要合并的文件")
回复

使用道具 举报

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

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-5-15 09:51 , Processed in 0.289886 second(s), 9 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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