ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 工作簿1中用VB打开另一个工作簿2,并汇总工作簿2数据到工作簿1

[复制链接]

TA的精华主题

TA的得分主题

发表于 2018-8-16 16:45 | 显示全部楼层 |阅读模式
本帖最后由 nihao123456789 于 2018-8-16 17:00 编辑

求高手帮忙,我在excel(工作簿1)中用VB打开另一个excel(工作簿2),想查询工作簿2中的所有的sheet,要怎样做?我需要把工作簿2中所有数据(每个sheet记录数量不一)复制到工作簿1(同一个sheet中)。

Sub 111()
MyPath = ThisWorkbook.Path & "\"
MyName = "工作簿2.xlsx"
        With Workbooks.Open(MyPath & MyName)               
            '求中间语言。。。。。。。。。。。。。。。
       .Close False
        End With
End Sub

本来可以用
for eash sh in workbook
next
但是我发现没有用。


求写关键语句。语法稍微有错误无所谓。

工作簿数据合并.rar

23.71 KB, 下载次数: 21

TA的精华主题

TA的得分主题

发表于 2018-8-16 16:51 来自手机 | 显示全部楼层
跨工作簿在不打开工作簿的情况下建议釆用ADO+SQL

TA的精华主题

TA的得分主题

发表于 2018-8-16 16:58 | 显示全部楼层

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-8-16 17:00 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-8-16 17:06 | 显示全部楼层
本帖最后由 zjdh 于 2018-8-16 17:57 编辑

Sub TEST()
    MyPath = ThisWorkbook.Path & "\"
    MyName = "工作簿2.xlsx"
    With Workbooks.Open(MyPath & MyName)
        For Each SH In .Sheets
            SH.UsedRange.Offset(1).Copy ThisWorkbook.Sheets(1).Range("A65536").End(3)(2)
        Next
        .Close False
    End With
End Sub

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2018-8-16 17:47 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
Sub getData()
    Dim cnn As Object, rst As Object, p$, f$, Sql$, r%, c&, i%, s$
    Set cnn = CreateObject("adodb.connection")
    p = ThisWorkbook.Path & "\"
    f = "工作簿2.xlsx"
    cnn.Open "Provider=Microsoft.ACE.OLEDB.12.0;Extended Properties='Excel 12.0;HDR=yes';Data Source=" & p & f
    Set rst = cnn.OpenSchema(20)
    Do Until rst.EOF
        If rst.Fields("TABLE_TYPE") = "TABLE" Then
          s = Replace(rst("TABLE_NAME").Value, "'", "")
          If Right(s, 1) = "$"  Then
            Sql = Sql & "Union All Select 列1,列2,列3,列4,列5,列6 From [" & s & "a3:f] "
'            Sql = Sql & "Union All Select * From [" & s & "a3:f] "
          End If
        End If
        rst.MoveNext
    Loop
    rst.Close
    Sql = Mid(Sql, 11)
    Set rst = cnn.Execute(Sql)
    Dim ar, br(1 To 16888, 1 To 6), k&
    ar = rst.GetRows
    k = 0
    For c = 0 To UBound(ar, 2)
        If ar(1, c) <> "" Then
            k = k + 1
            For r = 0 To UBound(ar)
                br(k, r + 1) = ar(r, c)
            Next
        End If
    Next

    With Me
        .Cells = ""
        For i = 1 To rst.Fields.Count
            .[a3].Offset(0, i - 1) = rst.Fields(i - 1).Name
        Next
        .[a4].Resize(k, 6) = br
    End With
    cnn.Close
    Set cnn = Nothing
    Set rst = Nothing
End Sub

TA的精华主题

TA的得分主题

发表于 2018-8-16 17:51 | 显示全部楼层
xiangbaoan 发表于 2018-8-16 17:47
Sub getData()
    Dim cnn As Object, rst As Object, p$, f$, Sql$, r%, c&, i%, s$
    Set cnn = Cre ...

………………又不审核了,附件…………

工作簿1.rar

17.42 KB, 下载次数: 37

仅供测试

TA的精华主题

TA的得分主题

发表于 2018-8-16 21:09 | 显示全部楼层
代码仅供参考
  1. Sub 汇总()
  2. t = Timer
  3. Dim cnn As Object, rs As Object
  4. Dim sql$, mypath$, myname$
  5. Dim ws As Worksheet
  6. Dim arr, brr(1 To 10000, 1 To 6)
  7. Application.ScreenUpdating = False
  8. mypath = ThisWorkbook.Path & ""
  9. myname = Dir(mypath & "工作簿2.xlsx")
  10. Set wb = GetObject(mypath & myname)
  11. With wb
  12.    For Each ws In .Worksheets
  13.      Set cnn = CreateObject("ADODB.Connection")
  14.      cnn.Open "Provider=Microsoft.ACE.OLEDB.12.0;extended properties='excel 12.0;HDR=yes';Data Source=" & mypath & myname
  15.      sql = "select * from [" & ws.Name & "$a3:f]"
  16.      Set rs = cnn.Execute(sql)
  17.      arr = rs.GetRows
  18.      For i = 0 To UBound(arr, 2)
  19.        m = m + 1
  20.        For j = 0 To 5
  21.          brr(m, j + 1) = arr(j, i)
  22.        Next
  23.      Next
  24.   Next
  25. End With
  26. ThisWorkbook.Worksheets("汇总").UsedRange.Offset(1).ClearContents
  27. [a4].Resize(m, 6) = brr
  28. rs.Close
  29. cnn.Close
  30. Set rs = Nothing
  31. Set cnn = Nothing
  32. Application.ScreenUpdating = True
  33. MsgBox "共用时 " & Format(Timer - t, "0.0000") & "秒", vbInformation
  34. End Sub
复制代码

TA的精华主题

TA的得分主题

发表于 2018-8-16 21:10 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
汇总sql 123.rar (28.36 KB, 下载次数: 54)

TA的精华主题

TA的得分主题

发表于 2018-8-17 22:24 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
zjdh 发表于 2018-8-16 17:06
Sub TEST()
    MyPath = ThisWorkbook.Path & "\"
    MyName = "工作簿2.xlsx"

大师,请教 SH.UsedRange.Offset(1).Copy ThisWorkbook.Sheets(1).Range("A65536").End(3)(2) 这句最后的(2)如何理解?
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2025-1-12 07:44 , Processed in 0.029710 second(s), 13 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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