ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 合并不同文件夹下相同名称的工作簿内的工作表到同一个工作表

[复制链接]

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-6-2 17:27 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

老师您好,我希望能够按同名工作簿进行分类形成新的合并工作簿,具体参照附件哈,此外不知道为什么程序跑出来后被合并的第一个工作簿中含中文的列的内容都会丢失,我把测试的结果也加到附件中了,麻烦您了

汇总v2.rar

1.62 MB, 下载次数: 10

TA的精华主题

TA的得分主题

发表于 2016-6-2 17:40 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
vince鑫15 发表于 2016-6-2 17:13
老师,我再尝试了下,您的程序似乎是把所有工作簿都合并到了一个工作簿内哈,我希望的结果是by相同名称的 ...

Sub ADO法()
    Dim cnn As Object, rs As Object, SQL$, Fso As Object, Folder As Object, i&, j&, l&, wb As Workbook, d As Object, k, t, arr
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    Set d = CreateObject("scripting.dictionary")
    Set cnn = CreateObject("adodb.connection")
    Set Fso = CreateObject("Scripting.FileSystemObject")
    Set Folder = Fso.GetFolder(ThisWorkbook.Path & "\数据")
    Call GetFiles(Folder, d)
    Set wb = Workbooks.Add(xlWBATWorksheet)
    cnn.Open "Provider=Microsoft.ACE.OLEDB.12.0;Extended Properties=excel 12.0;Data Source=" & ThisWorkbook.FullName
    k = d.keys
    t = d.items
    For i = 0 To d.Count - 1
        arr = Split(t(i), ",")
        With wb.Sheets(1)
            .Cells.ClearContents
            For j = 0 To UBound(arr)
                SQL = "select * from [Excel 12.0;Database=" & arr(i) & "].[Sheet1$]"
                Set rs = cnn.Execute(SQL)
                If j = 0 Then
                    For l = 1 To rs.Fields.Count
                        .Cells(1, l) = rs.Fields(l - 1).Name
                    Next
                    .[a2].CopyFromRecordset rs
                Else
                    .Range("a" & .Rows.Count).End(xlUp).Offset(1).CopyFromRecordset cnn.Execute(SQL)
                End If
            Next
            wb.SaveAs ThisWorkbook.Path & "\需要得到的结果\" & k(i)
        End With
    Next
    wb.Close
    Set Folder = Nothing
    Set Fso = Nothing
    rs.Close
    Set rs = Nothing
    cnn.Close
    Set cnn = Nothing
    Application.ScreenUpdating = True
    MsgBox "ok"
End Sub

Sub GetFiles(ByVal Folder As Object, d As Object)
    Dim SubFolder As Object
    Dim File As Object
    For Each File In Folder.Files
        If File.Name Like "*.xlsx" Then
            If Not d.Exists(File.Name) Then
                d(File.Name) = File
            Else
                d(File.Name) = d(File.Name) & "," & File
            End If
        End If
    Next
    For Each SubFolder In Folder.SubFolders
        Call GetFiles(SubFolder, d)
    Next
End Sub

TA的精华主题

TA的得分主题

发表于 2016-6-2 17:41 | 显示全部楼层
请测试附件
汇总v2.rar (677.9 KB, 下载次数: 351)

TA的精华主题

TA的得分主题

发表于 2016-6-2 19:22 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
留下记号,正是需要的

TA的精华主题

TA的得分主题

发表于 2016-11-6 23:20 | 显示全部楼层

老师可以问下,怎么样能让文件夹下名称相同的工作簿合并成一个工作簿呢,

TA的精华主题

TA的得分主题

发表于 2016-11-6 23:21 | 显示全部楼层

老师可以问下,怎么样能让文件夹下名称相同的工作簿合并成一个工作簿呢,

TA的精华主题

TA的得分主题

发表于 2016-11-6 23:22 | 显示全部楼层

老师可以问下,怎么样能让文件夹下名称相同的工作簿合并成一个工作簿呢,

TA的精华主题

TA的得分主题

发表于 2016-12-6 09:41 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2016-12-6 10:32 | 显示全部楼层
本帖最后由 226cc 于 2016-12-6 10:34 编辑

需要vba实现的~~各位大能帮看看啦。谢谢
http://club.excelhome.net/thread-1316011-1-1.html
(出处: ExcelHome技术论坛)
打扰楼主了,羡慕你有能人帮你看看。不好意思啊,@zhaogang1960能帮我看看吗。。。。。

TA的精华主题

TA的得分主题

发表于 2016-12-25 20:08 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
老师好,如果在原始的excel中把sheet1工作表的名字改成了其他的,程序应该怎么进行更改呢?目的就是把文件夹中子文件夹下所有的excel更改过名字的sheet1进行数据合并到一个新的工作簿的工作表中
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2025-1-15 18:25 , Processed in 0.027828 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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