新大榭论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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

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

查看: 944|回复: 0

[Excel课程] VBA程序也玩自动升级

[复制链接]
发表于 2008-7-9 14:33:43 | 显示全部楼层 |阅读模式

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

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

x
最近用VBA帮公司其他部门的同事写了一个数据管理的小工具,让他们以前每天要花1、2个钟头处理的工作现在10几分钟就搞定,还不容易出错,博得不少喝彩。终于,这些个家伙们提出越来越多新的要求,一会要求导出的报表增加这个项目,一会要求增加那个功能。倒是难不倒咱,很快修改了窗体代码,然而他们却连导入窗体都不会操作,还得跑到他们电脑前去(办公室可不在一起呀,一次两次就算了,可却经常发生,又不好意思拒绝,几经尝试,终于找到了一个解决办法:
+ o- T& B- S2 u( U: ~1 N# ]$ }5 j 为了好看,也为了防止误操作,所有他们可见的界面都是窗体,每次要求修改的东西也都是通过修改窗体代码完成的,那么,在工具上加上个自动升级功能,每次我写好新窗体后,导出到共享盘上,文件自动查找有没有新窗体文件存在,有,则先删除原来的窗体,再导入新窗体(要求同名),不就搞定了吗?不多说了,上代码:

  1. & u3 Q3 K* D( f
  2. Sub 升级()) M3 T" e0 y3 X. H7 t" j- s! o) o: p/ n: o
  3. Application.ScreenUpdating = False" C. L) G7 R& J  V
  4. On Error Resume Next
    ( D/ D+ z' T" s' b$ k
  5.    Dim pw$
    5 J" i4 M/ ]: Q1 ]) [8 O; ^
  6. '因为要用代码操作窗体需要先解开VBA工程密码(无密码就不用了),先解开:
    # v+ i; k( f  ]; V: s  h- {
  7.    pw = "1234" 'VBA工程密码
    1 M9 m1 {6 j# H2 l8 |! k5 m
  8.    If ThisWorkbook.VBProject.Protection = vbext_pp_locked Then, Y3 j# j) u. ^9 f, W
  9.      Application.VBE.CommandBars(1).Controls("工具(T)").Controls("VBAProject 属性(&E)...").Execute+ P# ?, w8 D% t9 z% u
  10.      Application.SendKeys pw & "{ENTER}{ENTER}"5 v# q  _+ H, T  m
  11.      DoEvents
    : K; Z4 N# p. J# c
  12.    End If( A6 S7 f: E- X
  13. & J. k7 g9 W/ {4 _* Y" O
  14. '还要求工具(T)-宏(M)-安全性(M)-可靠发行商(T)-勾选了“信任对于VB项目的访问(V),就别手工了,自动来:
    3 J$ _+ r3 W  e5 ]  r8 e# a  P' A/ R
  15.    Dim Chgset As Boolean9 R, }5 S1 d, A* C4 m
  16.    '陷阱测试,VBProject.Protection在这儿并无实际的意义4 H. v  t& ?8 H) R5 X4 g% O, p
  17.    Debug.Print ThisWorkbook.VBProject.Protection
    : v1 ]* U9 t- ]1 Q
  18.    If Err.Number = 1004 Then
    8 R" f5 K/ I% c* {
  19.      Err.Clear
    ' S3 ?- U' j2 O$ B4 X
  20.      Application.SendKeys "%TMS%T%V{ENTER}": }0 L: g, ?, z, p" i9 s- u# p
  21. Chgset = True- o7 E8 ?& b! t- J, A6 _( a- z
  22. DoEvents5 l9 \$ ?7 ^8 D
  23.    End If
    - K5 p' f' x6 d0 U% b2 r
  24.    '执行升级操作:1 i6 D1 Y3 e, r! d9 J
  25. Dim vbCmp As VBComponent* o5 `& ], W  ?8 ~/ `' z. }. ]6 O8 L
  26. Dim fname As String: E) q( `, J$ O$ w- U5 g. L1 b7 V
  27.    For Each vbCmp In ThisWorkbook.VBProject.VBComponents& U7 ^6 c+ c# r
  28.      If vbCmp.Type = vbext_ct_MSForm Then 'ThisWorkbook.VBProject.VBComponents.Remove vbCmp
    7 e  B' P3 v/ Z5 X$ W
  29.      fname = vbCmp.Name
    & i" `0 S# K/ W$ J/ u  T2 x( m( n4 S7 V
  30.      If Dir("共享路径" & fname & ".frm") <> "" Then0 q: K' r# k& W* b/ O
  31.      Application.VBE.ActiveVBProject.VBComponents.Remove ThisWorkbook.VBProject.VBComponents(fname)" R* p5 \; c0 A. i8 H
  32.      Application.VBE.ActiveVBProject.VBComponents.Import "共享路径"  & fname & ".frm"
    ( x: z( y% Q, q2 h7 }
  33.      End If
    0 b0 ^: u$ w2 z9 Z0 R# s# r
  34.      End If
    - ~( k/ x; ~2 @. U- m/ V
  35.    Next vbCmp
    + P3 u$ M9 p4 t8 y
  36.    MsgBox "升级完成": r: t' v- s$ W& G7 e+ G6 B
  37.    5 {# |% Y! E+ H8 t! ~' {
  38.    '操作完成后还原操作前的状态( O2 U8 d& F' w1 ?  V& d
  39. Application.ScreenUpdating = True
    ! [1 @- j; l/ R1 H+ ~6 v8 U  Y( p
  40. If Chgset Then Application.SendKeys "%TMS%T%V{ENTER}"
    ' \+ W5 {6 R! S2 |0 V- u. O- t$ }( h
  41. End Sub, u% A( T$ t" g$ O* W
复制代码
当然了,这里是直接开始升级了,如果需要,加上个升级文件是否存在的判断也行。
新大榭Python学习社区培训、Excel业务指导、办公软件定制、网站建设;新大榭探索实验室欢迎您!http://lab.daxie.net.cn/
Q群推荐 大榭本地求职招聘QQ群,欢迎转发分享本地招聘信息资讯! 官方招聘1群(已满);官方招聘2群:315816937 *
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

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

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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