ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

如何提取多个工作簿同一位置的数据

[复制链接]

TA的精华主题

TA的得分主题

发表于 2023-2-5 13:16 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
写了一段代码,运行的时候没有报错,运行后也提示“完成”,但没有抽取到任何数据,请各位大神帮忙看下这段代码哪里存在问题,感谢!
目的:成功抽取到工作簿里“主2增值税预缴表”表D10单元格的值。



Sub 按钮9_Click()
'//弹出窗口,让用户选择需要合并的工作簿
    MsgBox "请选择需要汇总的项目成本核对底稿"
    pth = Application.GetOpenFilename("文件(*.xls*),*.xls*", , "请选择文件", , 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 '获取代码工作簿已使用的最大行号+1
        With thissht 'with结构,简化代码
            Cells(1, 1) = 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



TA的精华主题

TA的得分主题

发表于 2023-2-6 07:15 来自手机 | 显示全部楼层
本帖最后由 杨建营 于 2023-2-6 09:03 编辑

with thissht
.cells在这里少一个点
还有就是应该用一个区域保存你提取的数值,除非是只有一个数值。

With thissht
        .Cells(i, 1) = sheeta.Range("D10")
End With

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-2-8 09:21 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
杨建营 发表于 2023-2-6 07:15
with thissht
.cells在这里少一个点
还有就是应该用一个区域保存你提取的数值,除非是只有一个数值。

加上.之后就能取到数了。太感谢你啦~
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-25 20:53 , Processed in 0.024953 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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