VBA调用RAR软件实现Excel自动压缩和解压功能
- 2017-09-08 22:47:00
- 网络摘录 转贴
- 14357
Excel VBA高级编程:VBA控制RAR软件实现Excel自动压缩和解压功能
网友们可能用过VBA来实现压缩文件,其实就是VBA利用WINRAR的一些命令通过 SHELL这个函数来实现!
先来为大家说说Shell函数:
Shell函数是VB中的内部函数,它负责执行一个可执行文件,返回一个Variant(Double),如果成功的话,代表这个程序的进程ID,若不成功,则会返回0。(这个函数也可以在VBA中使用。)
Shell的语法是:Shell(PathName[,WindowStyle])。
PathName:为必需参数。类型为String,它指出了要执行的程序名,以及任何需要的参数或命令行变量,也可以包括路径名。
WindowStyle:为可选参数。Integer类型,指定在程序运行时窗口的样式。WindowStyle有以下这些值。
常量值 描述
VbHide 0 窗口被隐藏,且焦点会移到隐式窗口。
VbNormalFocus 1 窗口具有焦点,且会还原到它原来的大小和位置。
VbMinimizedFocus 2 窗口会以一个具有焦点的图标来显示(缺省值)。
VbMaximizedFocus 3 窗口是一个具有焦点的最大化窗口。
VbNormalNoFocus 4 窗口会被还原到最近使用的大小和位置,而当前活动的窗口仍然保持活动。
VbMinimizedNoFocus 6 窗口会以一个图标来显示,而当前活动的窗口仍然保持活动。
再介绍下所需要结合运用的WinRar的用法
主要介绍以下如何在WinRar中用命令行来压缩和解压缩文件?
压缩:WINRAR A [-switches] [Files] [@Filelists]
例如你想把Test.mdb压缩到C盘下,可以WINRAR A C:\try.rar C:\Test.mdb
解压缩:如果带目录解压缩
WINRAR X [-switches] [Files] [@Filelists] [destionationfolder]
如果在当前目录解压缩,即解压缩时不写目录名
WINRAR E [-switches] [Files] [@Filelists] [destionationfolder]
例如你想把try.rar解压缩到C盘下,可以WINRAR X C:\try.rar C:\Test.mdb
最后以一个实际例子给大家一个参考
在VBA中新建一个模块,在模块中添加两个子程序压缩文件和解压缩文件。
压缩文件子程序是把文件Test.mdb压缩成try.rar。
Sub 压缩文件() Dim Rarexe As String 'WINRAR执行文件的位置 Dim Source As String '压缩前的原始文件 Dim Target As String '压缩后的目标文件 Dim FileString As String 'Shell指令中的字符串 Dim Result As Long Rarexe = "C:\program files\winrar\winrar" Source = "C:\Test.mdb" Target = "C:\try.rar" FileString = Rarexe & " a " & Target & " " & Source Result = Shell(FileString, vbHide) End Sub
解压的过程类似,解压缩文件子过程是把try.rar解压生成Test.mdb。在执行了上面的压缩过程后,可以删除文件Test.mdb,来解压缩重新生成Test.mdb。
Sub 解压缩文件() Dim Rarexe As String 'WINRAR执行文件的位置 Dim Source As String '解压缩前的原始文件 Dim Target As String '解压缩后的目标文件 Dim FileString As String 'Shell指令中的字符串 Dim Result As Long Rarexe = "C:\program files\winrar\winrar" Source = "C:\try.rar" Target = "C:\Test.mdb" FileString = Rarexe & " X " & Source & " " & Target Result = Shell(FileString, vbHide) End Sub
- office课程播放地址及课程明细
- Excel Word PPT Access VBA等Office技巧学习平台
- 将( .accdb) 文件格式数据库转换为早期版本(.mdb)的文件格式
- 将早期的数据库文件格式(.mdb)转换为 (.accdb) 文件格式
- KB5002984:配置 Jet Red Database Engine 数据库引擎和访问连接引擎以阻止对远程数据库的访问(remote table)
- Access 365 /Access 2019 数据库中哪些函数功能和属性被沙箱模式阻止(如未启动宏时)
- Access Runtime(运行时)最全的下载(2007 2010 2013 2016 2019 Access 365)
- Activex控件或Dll 在某些电脑无法正常注册的解决办法(regsvr32注册时卡住)
- office使用部分控件时提示“您没有使用该ActiveX控件许可的问题”的解决方法
- RTF文件(富文本格式)的一些解析
- Access树控件(treeview) 64位Office下出现横向滚动条不会自动定位的解决办法
- Access中国树控件 在win10电脑 节点行间距太小的解决办法
- EXCEL 2019 64位版(Office 2019 64位)早就支持64位Treeview 树控件 ListView列表等64位MSCOMMCTL.OCX控件下载
- VBA或VB6调用WebService(直接Post方式)并解析返回的XML
- 早期PB程序连接Sqlserver出现错误
- MMC 不能打开文件C:/Program Files/Microsoft SQL Server/80/Tools/Binn/SQL Server Enterprise Manager.MSC 可能是由于文件不存在,不是一个MMC控制台,或者用后来的MMC版
- sql server连接不了的解决办法
- localhost与127.0.0.1区别
- Roych的浅谈数据库开发系列(Sql Server)
- sqlserver 自动备份对备份目录没有存取权限的解决办法
- 安装Sql server 2005 express 和SQLServer2005 Express版企业管理器 SQLServer2005_SSMSEE
联系人: | 王先生 |
---|---|
Email: | 18449932@qq.com |
QQ: | 18449932 |
微博: | officecn01 |