ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

跨工作簿取数位置不正确

[复制链接]

TA的精华主题

TA的得分主题

发表于 2023-2-8 15:07 | 显示全部楼层 |阅读模式
各位大神:

      写了一段代码,选择多个汇总工作簿后,取数只能取到最后一个工作簿中的数据,并且位置不正确,希望大神们帮忙看看是哪里的问题,多谢!
image.png image.png
代码如下:

Sub 按钮1_Click()
'//弹出窗口,让用户选择需要合并的工作簿
    MsgBox "请选择需要汇总的纳税底稿"
    pth = Application.GetOpenFilename("文件(*.xlsx*),*.xlsx*", , "请选择文件", , True) 'GetOpenFilename支持通配符,true代表允许多选。
    If Not IsArray(pth) Then '如果用户没有选择文件,则返回False,不是数组。
        Exit Sub '退出过程
    End If
    '//
    Application.ScreenUpdating = False '禁止刷新,防止屏幕闪烁,提高运行速度
    Application.AskToUpdateLinks = False '禁止提示更新链接
    Application.DisplayAlerts = False '禁止无关的提示信息
    Set thissht = ThisWorkbook.ActiveSheet '把代码工作簿的活动工作表赋值给对象变量thissht
    For i = 1 To UBound(pth) 'GetOpenFilename多选文件的话返回的是一个数组,里面存放的是每个文件的路径,循环数组获取里面的文件路径。
        Set wb = Workbooks.Open(pth(i)) '将打开的工作簿赋值给对象变量wb
        Set sheeta = wb.Worksheets("主2增值税预缴表") '
        lastrow = thissht.Cells(thissht.Rows.Count, 1).End(3).Row '获取代码工作簿已使用的最大行号+1
        With thissht 'with结构,简化代码
            .Cells(lastrow, 1) = i '序号
            .Cells(lastrow, 4) = sheeta.Range("D10") '抽取工作表【主2增值税预缴表】的D10单元格
        End With
        wb.Close False '关闭打开的工作簿,直接用对象变量wb.clsoe即可。false表示不保存。
    Next
    Application.ScreenUpdating = True '开启刷新
    Application.AskToUpdateLinks = True '开启提示更新链接
    Application.DisplayAlerts = True '开启无关的提示信息
    MsgBox "完成!"
End Sub


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

本版积分规则

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

GMT+8, 2024-12-27 10:56 , Processed in 0.034424 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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