|
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件 ★ 免费下载 ★ ★ 使用帮助★
本帖最后由 cooloaky 于 2013-1-1 19:16 编辑
之前写过一个帖子,谈了一些关于excel程序开发的见解(http://club.excelhome.net/thread-816861-1-1.html)。最近对以加载宏形式开发的程序进行了研究,一些心得和大家分享。
所谓以excel加载宏形式开发的程序,指的是主程序文件为一个或多个excel addin(.xla / .xlam),外加其他程序所需文件(包括配置文件,数据文件,模板文件,帮助文件等等)构成的一个以实现某些既定功能的程序。加载宏文件基本都是放置在本地,而其他文件按程序实现的需要,可以放在本地,也可以放在文件服务器上。
前文中提到加载宏形式开发的程序,由于加载宏需要安装,而普通用户对excel的掌握程度很难控制,因此对程序的升级带来很多麻烦。开发者可能需要跑到每一个用户那里去手把手的进行一些文件的更新。特别是excel加载宏不支持uninstall方法。
经过一段时间的摸索,实现了多用户一键式安装和升级。方案如下:
1、建立了一个文件数据库dbFiler.accdb,放置在文件服务器上,路径固定;
2、写了一个FileMgr.xlam来管理dbFiler.accdb,用来添加并标识一些文件;
3、制作一个setup.xlsm的程序文件,用来安装程序。操作步骤为:写入配置信息(如路径,建立ODBC等)-》卸载加载宏(如有)并记录加载宏所在位置-》从dbfiler下载文件并覆盖原文件-》重新加载宏文件-》写入版本信息;
4、将所有程序文件上传到dbfiler.accdb(包括程序文件和上一步制作的安装文件)并加以标识;
5、在主程序文件(addin)中添加一个"检查更新"的功能,当触发该功能时,自动检索已安装程序版本号和可用最新版本号,如小于最新版本号,则从dbfiler中下载安装文件下来。
通过以上部署,经检测可用较完美的实现用户自助式安装和升级。
附件为我制作的dbfiler.accdb和filemgr.xlam,供大家参考。
dbfiler.zip
(371.36 KB, 下载次数: 153)
(VBA password: cooloaky)
注意:
由于DBFILER.ACCDB需部署在文件服务器上,因此需要将filemgr.xlam的VBA代码中,将Public Const GetDB As String = "\\Server\dbfiler.accdb"改为你所制定的路径。filemgr.xlam将按这个路径去找dbfiler.accdb。
|
|