新大榭论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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

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

查看: 1032|回复: 0

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

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

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

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

x
最近用VBA帮公司其他部门的同事写了一个数据管理的小工具,让他们以前每天要花1、2个钟头处理的工作现在10几分钟就搞定,还不容易出错,博得不少喝彩。终于,这些个家伙们提出越来越多新的要求,一会要求导出的报表增加这个项目,一会要求增加那个功能。倒是难不倒咱,很快修改了窗体代码,然而他们却连导入窗体都不会操作,还得跑到他们电脑前去(办公室可不在一起呀,一次两次就算了,可却经常发生,又不好意思拒绝,几经尝试,终于找到了一个解决办法:
- W+ O" G  v: G5 H( {) u 为了好看,也为了防止误操作,所有他们可见的界面都是窗体,每次要求修改的东西也都是通过修改窗体代码完成的,那么,在工具上加上个自动升级功能,每次我写好新窗体后,导出到共享盘上,文件自动查找有没有新窗体文件存在,有,则先删除原来的窗体,再导入新窗体(要求同名),不就搞定了吗?不多说了,上代码:
  1. 9 u  z& r- n, o/ ~& S2 \5 P' y
  2. Sub 升级()
    & a2 @) J" j# |. i( W# ?7 j
  3. Application.ScreenUpdating = False( z" I2 d3 ?& m% N* o
  4. On Error Resume Next
    : j! f& F0 ~2 y: k( s# z! g( a. q
  5.    Dim pw$# k& ^; X/ n# l4 Q
  6. '因为要用代码操作窗体需要先解开VBA工程密码(无密码就不用了),先解开:: H' H) T. x4 Q8 Z
  7.    pw = "1234" 'VBA工程密码
    9 `) j7 d3 h. `  f& M
  8.    If ThisWorkbook.VBProject.Protection = vbext_pp_locked Then1 D, E- G$ c4 i: _. w# s5 a
  9.      Application.VBE.CommandBars(1).Controls("工具(T)").Controls("VBAProject 属性(&E)...").Execute$ `; s* L% E; S" j& d+ ~
  10.      Application.SendKeys pw & "{ENTER}{ENTER}"
    ! b. d5 `+ V& ^( O
  11.      DoEvents
    ' `4 U, z* ^, b9 Q. C3 ]0 v
  12.    End If
    7 Y- J  V: Q" f& g; o1 G

  13. 7 r) [  {' x  e% i+ t5 G7 J
  14. '还要求工具(T)-宏(M)-安全性(M)-可靠发行商(T)-勾选了“信任对于VB项目的访问(V),就别手工了,自动来:! T7 L, P8 ]% R" }
  15.    Dim Chgset As Boolean
    3 {8 z8 s0 p7 F; a
  16.    '陷阱测试,VBProject.Protection在这儿并无实际的意义, R' i! w# c4 ~0 L' w
  17.    Debug.Print ThisWorkbook.VBProject.Protection
    % P3 x9 ^# m0 w
  18.    If Err.Number = 1004 Then
    / A. d+ @4 l$ R2 q8 A
  19.      Err.Clear8 S/ R/ L+ C& p( m, y
  20.      Application.SendKeys "%TMS%T%V{ENTER}"
      }; D1 z5 v. z3 I6 q
  21. Chgset = True
    + F' |6 N" d/ l9 q# a
  22. DoEvents
    . x5 }& y. u6 S. h( K) Z
  23.    End If
    8 a: z* h& ]  I$ M+ L7 e$ `
  24.    '执行升级操作:+ q. e' }2 t2 n4 m
  25. Dim vbCmp As VBComponent
    * k! a4 `- h' w1 E$ }3 y2 w, F
  26. Dim fname As String
    ( _6 `) d! m" I" |- R. Y, T
  27.    For Each vbCmp In ThisWorkbook.VBProject.VBComponents" x6 l- H& ~. U
  28.      If vbCmp.Type = vbext_ct_MSForm Then 'ThisWorkbook.VBProject.VBComponents.Remove vbCmp
    # p. z! r- h# O) [  m
  29.      fname = vbCmp.Name
    ; N% H) ]( D& ^% ~. j  L
  30.      If Dir("共享路径" & fname & ".frm") <> "" Then. \' G$ S) h. e) Z, P% W
  31.      Application.VBE.ActiveVBProject.VBComponents.Remove ThisWorkbook.VBProject.VBComponents(fname)* y1 H* j2 o& d$ J/ D: R
  32.      Application.VBE.ActiveVBProject.VBComponents.Import "共享路径"  & fname & ".frm"0 j- o5 d1 }( N
  33.      End If* N) c# O$ d1 j: X
  34.      End If5 [. T$ t6 n* S1 [/ U7 i# g+ N
  35.    Next vbCmp4 @% b; [6 G+ p  T& H# r2 ^3 ?
  36.    MsgBox "升级完成"$ J( K3 @  t6 ?% o9 k
  37.    3 w/ m& G; j& J) U
  38.    '操作完成后还原操作前的状态+ X6 D# `; C' |' {3 |) u9 p( A
  39. Application.ScreenUpdating = True
    - C" C, Q) m& _, L7 W
  40. If Chgset Then Application.SendKeys "%TMS%T%V{ENTER}"
      X9 W8 Q8 m: ?" v0 t& c
  41. End Sub6 J% d9 l* p9 z; b* Z
复制代码
当然了,这里是直接开始升级了,如果需要,加上个升级文件是否存在的判断也行。
新大榭Python学习社区培训、Excel业务指导、办公软件定制、网站建设;新大榭探索实验室欢迎您!http://lab.daxie.net.cn/
Q群推荐 大榭本地求职招聘QQ群,欢迎转发分享本地招聘信息资讯! 官方招聘1群(已满);官方招聘2群:315816937 *
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-2-26 22:57 , Processed in 0.079590 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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