Dzwebs.Net

撰写电脑技术杂文十余年

VBA调用WinRAR压缩文件

Admin | 2011-10-20 9:45:52 | 被阅次数 | 8485

温馨提示!

如果未能解决您的问题,请点击搜索;登陆可复制文章,点击登陆

  VBA调用WinRAR压缩文件,其本质就是利用WinRAR的压缩命令来完成。

  而VBA要调用WinRAR,就得使用Shell函数来运行这个命令,具体介绍如下:

  一、WinRAR调用Shell函数的介绍

  Shell函数是VB中的内部函数,它负责执行一个可执行文件,返回一个Variant(Double),如果成功的话,代表这个程序的进程ID,若不成功,则会返回0。(PS:这个函数也可以在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]
  例如你想把good.mdb压缩到D盘下,可以WINRAR A C:\test.rar C:\good.mdb

  解压缩:如果带目录解压缩
  WINRAR X [-switches] [Files] [@Filelists] [destionationfolder]
  如果在当前目录解压缩,即解压缩时不写目录名
  WINRAR E [-switches] [Files] [@Filelists] [destionationfolder]
  例如你想把test.rar解压缩到D盘下,可以WINRAR X C:\test.rar C:\good.mdb

  三、 VBA调用WinRAR解压压缩文件的实例

  在VBA中新建一个模块,在模块中添加两个子程序压缩文件和解压缩文件。

  压缩文件子程序是把文件good.mdb压缩成test.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 = "e:\program files\winrar\winrar"
        Source = "d:\good.mdb"
        Target = "d:\test.rar"
        FileString = Rarexe & " a " & Target & " " & Source
        Result = Shell(FileString, vbHide)
    End Sub

  解压的过程类似,解压缩文件子过程是把test.rar解压生成good.mdb。在执行了上面的压缩过程后,可以删除文件good.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:\try.mdb"
        FileString = Rarexe & " X " & Source & " " & Target
        Result = Shell(FileString, vbHide)
  End Sub


该杂文来自: PowerPoint杂文

上一篇:PowerPoint使用擦除效果制作绘制曲线的动画

下一篇:幻灯片自定义放映只播放一部分幻灯片

网站备案号:

网站备案号:滇ICP备11001339号-7

版权属性:

Copyright 2007-2021-forever Inc. all Rights Reserved.

联系方式:

Email:dzwebs@126.com QQ:83539231 访问统计