新大榭论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

《新大榭》- 创大榭地方网络社区先锋品牌 新大榭始终专注于地方网络社区平台的建设 关于我们- [大记事]- 留言建议- [新手报道]

发布 .新大榭软件管家(Excel版) V5.9版 财务/仓库/生产/销售/采购/行政/人事/校园 .公告 - 客户 - 打赏 - 职场 - Excel - Python.

新大榭镜像-音乐-法律-图书-高中课堂-实验 广告是为了能更好的发展 [欢迎商家支持本站互利共赢] 广告位招租.首页黄金广告位等您来!联系 13566035181

查看: 738|回复: 4

[Excel课程] 不打开工作簿取得其他工作簿数据

[复制链接]
发表于 2020-4-5 20:45:46 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!

您需要 登录 才可以下载或查看,没有账号?注册

x
51-1        使用公式
  1. Sub CopyData_1()
    # l8 Y6 U! s, i* v2 ~& j
  2.       Dim Temp As String3 X- C( @& _+ P  C/ r8 _/ C0 H
  3.       Temp = "'" & ThisWorkbook.Path & "\[数据表.xls]Sheet1'!"" {. D9 \( l/ C; J( x; s
  4.       With Sheet1.Range("A1:F22")
    3 x- V* G4 Y- l
  5.           .FormulaR1C1 = "=" & Temp & "RC"( v" y0 ^; c, F7 _
  6.           .Value = .Value
    ' x, T' L( G+ q1 }* ?
  7.       End With
    , ]7 T$ P2 P& r1 j- p; t
  8.   End Sub
复制代码
4 O0 z* F. T0 B/ B8 h
代码解析& q- H2 O& h7 x! n
CopyData_1过程在工作表中写入公式引用“数据表”中同一位置单元格中的数据。, b# h: a' e; S+ r3 D. B) H8 C
第3行代码将引用工作簿的路径赋给变量Temp。
4 a+ O6 Z0 j5 @' {6 ]) I/ L第5行代码在作表中写入公式引用数据。+ R! ]' J. z5 }# k) t: j
第6行代码将公式转换为数值。
新大榭Python学习社区培训、Excel业务指导、办公软件定制、网站建设;新大榭探索实验室欢迎您!http://lab.daxie.net.cn/
Q群推荐 大榭本地求职招聘QQ群,欢迎转发分享本地招聘信息资讯! 官方招聘1群(已满);官方招聘2群:315816937 *
 楼主| 发表于 2020-4-5 21:46:28 | 显示全部楼层
51-2        使用GetObject函数
4 u' {+ r$ I  c8 ?' l, K1 b' T1 B+ F; n7 H7 s; ]. C+ O. k' K
  1. Sub CopyData_2()4 P, L% y# S) w" X2 Q6 S0 `9 g
  2.       Dim Wb As Workbook
    8 A. I% d) P, r" z# h8 F' }
  3.       Dim Temp As String: ~6 w, Q8 [+ _0 C# q
  4.       Application.ScreenUpdating = False
    & ~! V- N4 B4 ]
  5.       Temp = ThisWorkbook.Path & "\数据表.xls"( J# t( }" X& O8 X  n2 S! ]1 F
  6.       Set Wb = GetObject(Temp)$ O% F$ i& i' T5 i1 U. m1 w
  7.           With Wb.Sheets(1).Range("A1").CurrentRegion) f2 f- e3 e/ \2 q& d" h; r
  8.               Range("A1").Resize(.Rows.Count, .Columns.Count) = .Value, c2 I# N, d$ A# k# u8 t& I/ D
  9.               Wb.Close False8 M+ Y9 C" Q8 k7 s1 `, c" @$ @
  10.           End With
    ; [9 P2 c4 i" P  z
  11.       Set Wb = Nothing: C) @% c' o% S7 [4 a6 Y
  12.       Application.ScreenUpdating = True
    1 @: E% A* U6 q9 l. J, _' }; ^; X9 `
  13.   End Sub
复制代码

* [7 R, @* T+ p: E+ Z8 g% I$ q: K! L" f* z
代码解析2 t% w6 C: ]2 y) K7 q
CopyData_2过程使用GetObject函数来获取“数据表”工作簿中的数据。
, r" l" Y( `# }9 ?第4行代码关闭屏幕更新加快运行速度。! ^  H4 ]4 [, p7 `
第5行代码将引用工作簿的路径赋给变量Temp。
5 H6 w' a' j5 F5 u! _- _- a# |( b! ?第6行代码使用Set语句将GetObject函数返回的对象赋给对象变量Wb。( `4 k+ Y5 v; O8 P6 a
GetObject函数返回文件中的ActiveX对象的引用# A% O! k3 m7 u6 X- Y4 K" B
参数pathname是可选的,包含待检索对象的文件的全路径和名称。如果省略,则class参数是必需的。
" m" F' u' T0 R参数class是可选的,代表该对象的类的字符串。
' V9 e4 |8 U: ?( n第7行到第10行代码,当GetObject函数指定的对象被激活之后,就可以在代码中使用对象变量Wb来访问这个对象的属性和方法。' M4 A/ `" ]8 O0 T/ n
其中第7、8行代码将“数据表”工作簿中的第1张工作表已使用区域的数据赋给本工作表的单元格,第9行代码关闭“数据表”工作簿,使用GetObject函数返回对象的引用时,虽然在窗口中看不到对象的实例,但实际上是打开的,所以需用Close语句将其关闭。! N' S9 B# m1 _3 T0 q* c: ?
第12行代码开启屏幕更新。
4 L1 r7 e: q6 K9 H' y* H" ]$ g4 c3 c; c9 [8 `, I7 u
新大榭Python学习社区培训、Excel业务指导、办公软件定制、网站建设;新大榭探索实验室欢迎您!http://lab.daxie.net.cn/
新大榭官方公益帮帮群:6603298 官方Excel学习交流群:82064486  欢迎您加入
 楼主| 发表于 2020-4-5 21:48:16 | 显示全部楼层
51-3        隐藏Application对象
, {# {/ ~0 L; i& K通过隐藏Application对象来模拟不打开工作簿取数,如下面的代码所示。5 C: f/ P5 h; _) Q# |# v
  1. Sub CopyData_3()
    : B$ u6 L$ O* a7 A, U
  2.       Dim myApp As New Application
    5 w8 E# F+ M( f
  3.       Dim Sh As Worksheet8 b/ c# F  l- L+ k& Z; ]
  4.       Dim Temp As String
    8 |3 @5 q" X' o& ]9 \" J
  5.       Temp = ThisWorkbook.Path & "\数据表.xls"
    # A# T) ]9 c2 n1 Z8 b
  6.       myApp.Visible = False' U9 F! i! ?& b/ M( q1 Z
  7.       Set Sh = myApp.Workbooks.Open(Temp).Sheets(1)7 }" Y( v# V% d0 C* r& |
  8.       With Sh.Range("A1").CurrentRegion
    7 T$ ?* h8 ?& K9 u9 ?
  9.           Range("A1").Resize(.Rows.Count, .Columns.Count) = .Value2 O& m: Z6 l$ l  V
  10.       End With
    # z' Y+ b9 O! h5 L% B, I6 n
  11.       myApp.Quit( f' p7 x3 l0 E7 N, K8 t
  12.       Set Sh = Nothing
    " I% _7 r. M, ~- c/ O) j
  13.       Set myApp = Nothing* q2 q6 m- |2 t" u5 d
  14. End Sub
复制代码

* Z; h( u: l4 Z% m0 V- g. A* @$ `代码解析9 ~/ u( C: Y& G5 E/ ^1 S, W
CopyData_3过程隐藏Application对象来模拟不打开工作簿取数。! [# O1 L3 Y* {4 l& S, K# D
第2行代码使用New关键字隐式地创建一个Application对象。
$ Z% o( I' o: o" p% ?第6行代码将新创建的Application对象的Visible属性设置为False,使之隐藏。
0 n: D( `! D- j) c8 a- R' X第7行代码使用Open方法打开“数据表”工作簿(关于Open方法请参阅技巧42 ,因为工作簿是使用新创建的、隐藏的Application对象打开的,所以在窗口中是不可视的。
3 J5 l% T, s  z& |7 g3 T' t第8行到第10行代码将“数据表”工作簿中的第1张工作表已使用区域的数据赋给本工作表的单元格。
1 V' X7 }/ S+ z第11行代码使用Quit方法退出新打开的Excel程序。; K5 g5 y4 h0 W7 v9 \
新大榭Python学习社区培训、Excel业务指导、办公软件定制、网站建设;新大榭探索实验室欢迎您!http://lab.daxie.net.cn/
北仑单身女神专属群:181567400 北仑单身男神专属群:140788506  平台大数据筛选,勇敢为爱宣告,拒绝骚扰!
 楼主| 发表于 2020-4-5 21:50:52 | 显示全部楼层
51-4  使用ExecuteExcel4Macro方法
//  使用ExecuteExcel4Macro方法可以做到不打开工作簿的情况下获取其他工作薄中指定工作表的数据,如下面的代码所示。
  1. Sub CopyData_4()" O# n! A" s) i6 P; g% o+ j. D
  2.       Dim RCount As Long
    - T2 V' k1 x$ |
  3.       Dim CCount As Long' s) Y3 S0 t) j4 ^% R4 w
  4.       Dim Temp As String
    9 N& h9 |( ^4 Y8 i* q" {4 C# ]0 A! u
  5.       Dim Temp1 As String
    % y$ Y4 \% X) o
  6.       Dim Temp2 As String
    2 _$ u% B9 t" B+ r8 K9 b" l
  7.       Dim Temp3 As String! o, U9 D" X: a; g4 F' D8 B: r
  8.       Dim R As Long
    9 A4 v! U* `7 Y) g" C6 B0 V# A- x
  9.       Dim C As Long
    . E- B9 a' u7 G: ?1 }' i7 ^
  10.       Dim arr() As Variant
    $ X9 m* k/ z+ X% S5 J  A
  11.       Temp = "'" &ThisWorkbook.Path & "\[数据表.xls]Sheet1'!"0 a4 L7 E3 r% Y$ Q7 f
  12.       Temp1 = Temp & Rows(1).Address(, ,xlR1C1)
    % B5 v3 P: L9 Y# i; x' j
  13.       Temp1 = "Counta(" & Temp1& ")"
    6 g6 C. e  n/ X" `: L% b" \' v
  14.       CCount =Application.ExecuteExcel4Macro(Temp1)
    8 P$ @' z, W& M. J) O1 t3 w4 ?; u! s
  15.       Temp2 = Temp &Columns("A").Address(, , xlR1C1)  W% n% k+ Y: [
  16.       Temp2 = "Counta(" & Temp2& ")"7 d& I# ^/ v% ^  f
  17.       RCount = Application.ExecuteExcel4Macro(Temp2)
    + H, x" }9 h0 Y* A  s$ r6 f
  18.       ReDim arr(1 To RCount, 1 To CCount)
    0 J* j7 g  ?1 Z+ P( s  ^
  19.       For R = 1 To RCount
    / c9 W. W3 ~$ i) j
  20.           For C = 1 To CCount" |  P! f/ @0 }. H" v
  21.               Temp3 = Temp & Cells(R,C).Address(, , xlR1C1)- {# \. a; o2 l! ~, P1 N
  22.               arr(R, C) = Application.ExecuteExcel4Macro(Temp3)
    2 ?3 U6 k; p" t
  23.           Next
    , h) i- _. J( ]# n6 t: I7 U9 H8 O
  24.       Next+ Y! Q0 W) \5 R+ X/ z5 U& ?  T
  25.       Range("A1").Resize(RCount,CCount).Value = arr
    ( r$ ?2 G2 I& n
  26. End Sub
复制代码

. j+ W" U) M" D8 G( {
代码解析
CopyData_4过程使用ExecuteExcel4Macro方法获取“数据表”工作薄中指定工作表的数据。
第14、16行代码使用ExecuteExcel4Macro方法执行Counta函数取得“数据表”工作薄中指定工作表的行数和列数合计。
ExecuteExcel4Macro方法执行一个Microsoft Excel 4.0宏函数,然后返回此函数的结果,语法如下:
expression.ExecuteExcel4Macro(String)
参数expression是可选的,返回一个Application对象。
参数String是必需的,一个不带等号的Microsoft Excel 4.0宏语言函数,所有引用必须是像R1C1这样的字符串。
因为Microsoft Excel4.0 宏不在当前工作簿或工作表的环境中求值,所有的引用都是外部引用,所以无需打开引用工作簿但是需要明确指定工作簿名称。
第18行代码使用ReDim语句为动态数组arr重新分配存储空间。
第19行到第24行代码循环取值,将“数据表”工作薄中指定工作表的数据赋给动态数组arr。
第25行代码将动态数组arr的值赋给工作表的单元格。

7 ~! I% B4 i7 U# E% C
  L! ~3 d: n3 u4 B2 P3 t+ R% j" ~+ V7 l9 ?$ G
新大榭Python学习社区培训、Excel业务指导、办公软件定制、网站建设;新大榭探索实验室欢迎您!http://lab.daxie.net.cn/
 楼主| 发表于 2020-4-5 21:56:55 | 显示全部楼层
51-5        使用SQL连接& }3 ?: Z) i; ~4 v% I

; T8 e' W1 M( X1 ?* E- B0 h$ e# l$ C% ^1 A8 \4 g( ^
//  使用SQL建立与工作簿的连接,查询数据记录后复制到当前工作表中,如下面的代码所示。. ^; E) g; }: t4 y4 @
  1. Sub CopyData_5()
    # M2 I/ u0 a. m) c- p; W, q
  2.       Dim Sql As String5 p5 e. }5 |$ S8 f. u' b
  3.       Dim j As Integer
    5 p1 V7 ]7 s0 e
  4.       Dim R As Integer. ?9 }$ \. u6 g' w  j
  5.       Dim Cnn As ADODB.Connection$ I$ w- z% n/ B. a7 h& A
  6.       Dim rs As ADODB.Recordset
    & w5 S" @. F  n, L0 G9 U
  7.       With Sheet5
    2 E' A# a  L0 _/ Z9 B5 w7 v2 u
  8.           .Cells.Clear' b) ]$ e% C- s% X$ B* C
  9.           Set Cnn = New ADODB.Connection( F0 U# I/ m) C
  10.           With Cnn) `3 O' o: l# u8 @# F. d. r7 u
  11.               .Provider = "microsoft.jet.oledb.4.0"  D! y; ]# Y+ L+ }/ E: X* D% z
  12.               .ConnectionString = "Extended Properties=Excel 8.0;" _& {4 Y0 [) P* S4 d1 q! p
  13.                   & "Data Source=" & ThisWorkbook.Path & "\数据表"% N& ]% Z1 l/ @& y$ [1 y3 u' d
  14.               .Open
    + a6 B0 S+ ~. s
  15.           End With' L# \* E4 i6 K% K9 L
  16.           Set rs = New ADODB.Recordset
    ( ?2 E9 [- `# S  Y4 n
  17.           Sql = "select * from [Sheet1$]"
    % V: _$ y9 n# r
  18.           rs.Open Sql, Cnn, adOpenKeyset, adLockOptimistic2 M9 `5 P3 N8 J: Z3 C
  19.               For j = 0 To rs.Fields.Count - 16 h) @0 ^5 k0 `
  20.                   .Cells(1, j + 1) = rs.Fields(j).Name$ p9 e1 X5 r3 |, V
  21.               Next
    9 m' A+ B' t, o0 A: R4 _: a/ D3 @% J
  22.           R = .Range("A65536").End(xlUp).Row
    + Y5 P. l" o8 Z
  23.           .Range("A" & R + 1).CopyFromRecordset rs' u6 q1 F5 ~) z; ?  U3 r2 G  s
  24.       End With
    ! @! Z9 {8 r, U- ?0 N$ Z7 g7 r# b  N
  25.       rs.Close7 _* P6 `! `% W  w( p
  26.       Cnn.Close
    ( g* g: Q9 r1 Y9 d+ H+ _
  27.       Set rs = Nothing4 }, X- R; x: {1 X$ I0 U/ u# g" |
  28.       Set Cnn = Nothing
    & t" q( x5 K/ g% v7 q
  29. End Sub
复制代码

2 y1 R% {1 B: m9 w) |代码解析
$ \. M6 @0 D* FCopyData_5过程使建立与“数据表”工作簿的连接,查询数据记录后复制到当前工作表中。
/ l8 C4 x: e- R" f2 m' l3 Z+ ?第8行代码删除当前工作表的所有数据。0 C+ Q% x2 R5 g( r6 i
第9行到第15行代码建立与“数据表”工作簿的连接。: h( C+ h# y2 H5 s# m
第16行到第24行代码查询“数据表”工作簿的全部数据,并复制到工作表中。
8 N) G( `, H  `第20行代码将字段名称(标题行)复制到工作表中,5 m; j! I: s9 k- T
第23行代码将查询到的数据记录复制到工作表。2 R: e- Z. i& e, y. _

) h9 F( ?: \  y5 x, K; [9 n# v) c0 }

* q2 t( ~! j7 }% R
- D: V2 L. y; V3 R9 u0 R* D! G# g' [; \0 y$ b
新大榭Python学习社区培训、Excel业务指导、办公软件定制、网站建设;新大榭探索实验室欢迎您!http://lab.daxie.net.cn/
您需要登录后才可以回帖 登录 | 注册

本版积分规则

文字版|小黑屋|新大榭 ( 浙ICP备16018253号-1 )|点击这里给站长发消息|

GMT+8, 2025-12-13 17:07 , Processed in 0.080693 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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