ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 如何不打开Excel文档,提取、操作文档中的数据?

[复制链接]

TA的精华主题

TA的得分主题

发表于 2014-2-25 16:40 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
1、文档路径:f:\shiyan\1.xls
2、sheets名:sheet1,sheet2,sheet3
3、希望得到i=f:\shiyan\1.xls 的sheet1.[a3],j=f:\shiyan\1.xls 的 sheet2.range("b2:f100")

麻烦各位老师帮忙。

TA的精华主题

TA的得分主题

发表于 2014-2-25 16:44 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
http://club.excelhome.net/thread-1058320-1-1.html参考下吧,看看能不能帮上你

TA的精华主题

TA的得分主题

发表于 2014-2-25 22:30 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
用getobject              

TA的精华主题

TA的得分主题

发表于 2014-2-25 23:34 | 显示全部楼层
如果你的数据比较规范,可使用ADO取得数据,请参考:
  1. Sub Macro1()
  2.     Dim cnn As Object, SQL$, i, j
  3.     Set cnn = CreateObject("ADODB.Connection")
  4.     cnn.Open "Provider = Microsoft.Jet.Oledb.4.0;Extended Properties ='Excel 8.0;hdr=no';Data Source =" & ThisWorkbook.Path & "\1.xls"
  5.     SQL = "select * from [Sheet1$a3:a3]"
  6.     i = cnn.Execute(SQL)(0)
  7.     MsgBox i
  8.     SQL = "select * from [Sheet2$b2:f100]"
  9.     j = cnn.Execute(SQL).GetRows'b2:f100是个区域,返回值是个数组
  10.     j = WorksheetFunction.Transpose(j)
  11.     Range("a1").Resize(UBound(j), UBound(j, 2)) = j   '测试效果
  12.     cnn.Close
  13.     Set cnn = Nothing
  14. End Sub
复制代码

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-3-3 14:56 | 显示全部楼层
liulang0808 发表于 2014-2-25 16:44
http://club.excelhome.net/thread-1058320-1-1.html参考下吧,看看能不能帮上你

感谢您帮忙。
参考了您提供的办法,在2007版本中,偶会出现过渡单元格数据提取不到的情况。

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-3-3 14:59 | 显示全部楼层
zhaogang1960 发表于 2014-2-25 23:34
如果你的数据比较规范,可使用ADO取得数据,请参考:

感谢您的指导,不知数据规范与否指的是?能帮忙再详细说明下么,如何算不规范的?
另,Range("a1").Resize(UBound(j), UBound(j, 2)) = j 这个语句令我受益良多。
再次感谢老师指导!

TA的精华主题

TA的得分主题

发表于 2014-3-3 16:31 | 显示全部楼层
andiy90 发表于 2014-3-3 15:31
另外,在2007版本中提示:外部表不是预期的格式,这个如何解决?

Jet.Oledb.4.0——Ace.Oledb.12.0
Excel 8.0——Excel 12.0

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-3-3 15:31 | 显示全部楼层
zhaogang1960 发表于 2014-2-25 23:34
如果你的数据比较规范,可使用ADO取得数据,请参考:

另外,在2007版本中提示:外部表不是预期的格式,这个如何解决?

TA的精华主题

TA的得分主题

发表于 2024-3-22 21:57 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-9-29 12:19 , Processed in 0.039097 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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