Access爱好者--
所属分类: 常见问题 作者: 王莉梅 更新日期:2003-10-17 19:33:08 阅读次数:154

VB中利用Winrar进行文件压缩


一些数据库文件(如Access文件)在远程传输过程中可能由于文件比较大而影响传递效果。如果进行压缩以后再传递,会减少传递时间,避免意外的发生,同时也保证了传递效果。我们在压缩文件时,最常用的压缩工具为WinRar和Winzip,笔者在VB编程过程中利用WinRar工具来压缩数据库文件,并完成远程传输,十分方便,在此向大家介绍一下。用WinZip的方法类似。

一、Shell函数
  Shell函数是VB中的内部函数,它负责执行一个可执行文件,返回一个Variant(Double),如果成功的话,代表这个程序的进程ID,若不成功,则会返回0。

  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] [@File lists]

  例如你想把try.mdb压缩到C盘下,可以WINRAR A C:\try.rar C:\try.mdb

  解压缩:如果带目录解压缩

      WINRAR X [-switches] [Files] [@File lists] [destionation folder\]

      如果在当前目录解压缩,即解压缩时不写目录名

      WINRAR E [-switches] [Files] [@File lists] [destionation folder\]

  例如你想把try.rar解压缩到C盘下,可以WINRAR X C:\try.rar C:\try.mdb

三、一个例子
  在VB中新建一个工程,在Form1中添加两个按钮Command1、Command2和Command3,把他们的Caption属性分别设为"压缩文件"、"解压缩文件"和"传递文件"。按Command1时把文件try.mdb压缩成try.rar。

  Private Sub Command1_Click()

  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.mdb"

  Target="C:\try.rar"

  FileString = rarexe & " a " & Target & " " & Source

  Result = Shell(FileString, vbHide)

  End Sub

  解压的过程类似,按Command2可以把try.rar解压生成 try.mdb。在执行了上面的压缩过程后,可以删除文件try.mdb,来解压缩重新生成try.mdb。

  Private Sub Command2_Click()

  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

  文件从一台计算机传输到另一台计算机前,应知道另一台计算机的名字,然后用FileCopy语句就可以了。假设要把压缩后try.rar传递到计算机名为"other"的共享目录"want"下。

  Private Sub Command3_Click()

  Dim SourceFile, DestinationFile

   SourceFile ="C:\try.rar " 指定源文件名。

   DestinationFile = "\\other\want\try.rar" 指定目的文件名。

   FileCopy SourceFile, DestinationFile 将源文件的内容复制到目的文件中。

  End Sub

  怎么样,十分简单吧?


--------------------------------------------------------------------------------
相关文章

两个未公开的ACCESS方法的使用技巧 2003-12-30 14:59:33
了解 Microsoft Access 安全性 2003-11-13 11:21:08
让控件自适应屏幕分辨率 2003-10-18 9:58:33
MS Jet SQL for Access 2000中级篇 (II) 2003-10-17 18:51:01
如何诊断/修复损坏的 Jet 4.0 数据库 2003-10-14 8:31:26
Access启动命令行选项大全 2003-10-10 10:02:00
优化Microsoft Access提高速度 2003-10-6 10:31:55


系统优化
控件使用
数据库设计
数据库连接
系统安全
OLE自动化
常见问题
实用代码
属性详解
网络相关
实用API
经验分享
精选教程
字符处理
ADP相关



文章搜索



制作维护:李寻欢     Mail:[email protected]

关于本站 -- 网站服务 -- 版权条款 -- 联系方法 -- 网站帮助
Access爱好者版权所有 Copyright 2003-2005 All Rights Reserved 未经许可不得盗链