一些数据库文件(如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 fileswinrarwinrar" 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 fileswinrarwinrar" 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 = "otherwanttry.rar" ‘ 指定目的文件名。 filecopy sourcefile, destinationfile ‘ 将源文件的内容复制到目的文件中。 end sub 怎么样,十分简单吧?
如何在 VB 中使用 Winzip 来压缩文件?
版本:VB6 / VB5 / VB4-32 现在压缩软件一大堆,但是如果您想在 VB 程式中做文件压缩的功能,您知道要怎么做吗?我不懂一些烦琐的压缩理论,但是我懂得利用现有的压缩软件来替我达到我想要的功能!在这个例子中,我要使用 Winzip 来做,所以,如果您想用下面的示例来做练习的话,先決条件就是您的电脑中一定要有安装 Winzip 才行!压缩文件 (加入文件):语法:winzip[32].exe [-min] action [options] filename[.zip] files参数说明:-min 最小化 指定 Winzip 执行时为最小化。如果您要使用 -min 这个参数,它必须是命令列参数的第一个参数。action 方法-a add 加入文件 -f freshen 重新整理目前文件 -u update 更新文件 -m move 移动文件 options 选项Directories 文件夹选项 -r Recurse Directories 含文件夹內內容。 -p Save Extra Directory Info 储存其他的文件夹信息。 method 決定压缩的方法选项 -ex eXtra 最大 (最慢) -en Normal 一般 (默认值) -ef Fast 快速 -es Super fast 最快速 -e0 no compression 不压缩 其他选项 -s 设定密码 密码必须使用双引号括起来。 例如:-s "Secret Password",不过要注意大小写是不同的! -hs 包含符合条件的隐藏及系统文件。 filename.zip 压缩文件名 指定压缩后的文件名,要注意的是必须是全路径文件名 (含磁碟機代号及文件夹)。 files 所有原始文件 一个或多个文件,每一个文件写在獨立的一行,可以使用萬用字元,例如:*.bak。 解压缩文件:语法:winzip[32].exe -e [options] filename[.zip] directory参数说明:-e 表示解压缩 是必要的参数!options 选项-o Overwrite existing files without prompting 取代同名的文件。 -j Junk pathnames 跳過舊文件。 除非指定 -J 这个参数,否則会使用原本的文件夹名稱。 -s 设定密码 密码必须使用双引号括起来。 例如:-s "Secret Password",不过要注意大小写是不同的! -hs 包含符合条件的隐藏及系统文件。 filename.zip 压缩文件名 指定压缩后的文件名,要注意的是必须是全路径文件名 (含磁碟機代号及文件夹)。directory 文件夹 解压缩后的文件存放的文件夹。如果文件夹不存在便会自动建立。 注意事项:※非常重要:永远使用全路径文件名 。 ※若希望执行 Winzip 时是最小化,要使用 -min 这个参数,它必须是命令列参数的第一个参数。 ※Winzip 內建只支援 zip 及 unzip 二种操作模式。 ※若是長文件名的话,必须使用双引号括起来。 ※在设定文件时,前面及最后的字元不可空白,也不可有空白行! ※在命令列中的方法及选项参数,至少要用一个以上的空白分隔。※WinZip 可以用来配合 cc:Mail 压缩文件: 更改 WMAIL.INI 中的 [cc:Mail] section 的 compress= 这一行 指定 Winzip 的完整路径,并跟随着 "-a %1 @%2" 参数 例如:如果 Winzip 安装在 c:\winzip,則 compress= 这一行必须改成 compress=c:\winzip\winzip.exe -a %1 @%2 示例: Private Sub Command1_Click() Dim wzipexe As String ' winzip 执行文件的位置 Dim wsource As String ' 原始文件 (压缩前) Dim wtarget As String ' 目地文件 (压缩后) Dim wcmd As String ' Shell 指令 Dim retval As Double ' Shell 指令传回值' Shell 指令 wzipexe = "C:\program files\winzip\WINzip32" ' winzip 执行文件的位置 wtarget = "d:\1.zip" ' 原始文件 (压缩前) wsource = "d:\1.mbd" ' 目地文件 (压缩后) wcmd = wzipexe & " -a " & wtarget & " " & wsource ' Shell 指令 retval = Shell(wcmd, 6) ' Shell 指令传回值 '上面的一大串可写成 'retval = Shell("C:\program files\winzip\WINzip32 -a _ 'd:\1.zip d:\1.mdb", 6) End Sub
9MB的数据库文件压缩后只有720k!
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 fileswinrarwinrar" 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 fileswinrarwinrar" 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 = "otherwanttry.rar" ‘ 指定目的文件名。 filecopy sourcefile, destinationfile ‘ 将源文件的内容复制到目的文件中。 end sub 怎么样,十分简单吧?
如何在 VB 中使用 Winzip 来压缩文件?
版本:VB6 / VB5 / VB4-32 现在压缩软件一大堆,但是如果您想在 VB 程式中做文件压缩的功能,您知道要怎么做吗?我不懂一些烦琐的压缩理论,但是我懂得利用现有的压缩软件来替我达到我想要的功能!在这个例子中,我要使用 Winzip 来做,所以,如果您想用下面的示例来做练习的话,先決条件就是您的电脑中一定要有安装 Winzip 才行!压缩文件 (加入文件):语法:winzip[32].exe [-min] action [options] filename[.zip] files参数说明:-min 最小化
指定 Winzip 执行时为最小化。如果您要使用 -min 这个参数,它必须是命令列参数的第一个参数。action 方法-a add 加入文件
-f freshen 重新整理目前文件
-u update 更新文件
-m move 移动文件 options 选项Directories 文件夹选项
-r Recurse Directories 含文件夹內內容。
-p Save Extra Directory Info 储存其他的文件夹信息。
method 決定压缩的方法选项
-ex eXtra 最大 (最慢)
-en Normal 一般 (默认值)
-ef Fast 快速
-es Super fast 最快速
-e0 no compression 不压缩
其他选项
-s 设定密码 密码必须使用双引号括起来。
例如:-s "Secret Password",不过要注意大小写是不同的!
-hs 包含符合条件的隐藏及系统文件。 filename.zip 压缩文件名
指定压缩后的文件名,要注意的是必须是全路径文件名 (含磁碟機代号及文件夹)。
files 所有原始文件
一个或多个文件,每一个文件写在獨立的一行,可以使用萬用字元,例如:*.bak。
解压缩文件:语法:winzip[32].exe -e [options] filename[.zip] directory参数说明:-e 表示解压缩
是必要的参数!options 选项-o Overwrite existing files
without prompting 取代同名的文件。
-j Junk pathnames 跳過舊文件。
除非指定 -J 这个参数,否則会使用原本的文件夹名稱。
-s 设定密码 密码必须使用双引号括起来。
例如:-s "Secret Password",不过要注意大小写是不同的!
-hs 包含符合条件的隐藏及系统文件。 filename.zip 压缩文件名
指定压缩后的文件名,要注意的是必须是全路径文件名 (含磁碟機代号及文件夹)。directory 文件夹
解压缩后的文件存放的文件夹。如果文件夹不存在便会自动建立。
注意事项:※非常重要:永远使用全路径文件名 。
※若希望执行 Winzip 时是最小化,要使用 -min 这个参数,它必须是命令列参数的第一个参数。
※Winzip 內建只支援 zip 及 unzip 二种操作模式。
※若是長文件名的话,必须使用双引号括起来。
※在设定文件时,前面及最后的字元不可空白,也不可有空白行!
※在命令列中的方法及选项参数,至少要用一个以上的空白分隔。※WinZip 可以用来配合 cc:Mail 压缩文件:
更改 WMAIL.INI 中的 [cc:Mail] section 的 compress= 这一行
指定 Winzip 的完整路径,并跟随着 "-a %1 @%2" 参数
例如:如果 Winzip 安装在 c:\winzip,則 compress= 这一行必须改成
compress=c:\winzip\winzip.exe -a %1 @%2
示例:
Private Sub Command1_Click()
Dim wzipexe As String ' winzip 执行文件的位置
Dim wsource As String ' 原始文件 (压缩前)
Dim wtarget As String ' 目地文件 (压缩后)
Dim wcmd As String ' Shell 指令
Dim retval As Double ' Shell 指令传回值' Shell 指令
wzipexe = "C:\program files\winzip\WINzip32" ' winzip 执行文件的位置
wtarget = "d:\1.zip" ' 原始文件 (压缩前)
wsource = "d:\1.mbd" ' 目地文件 (压缩后)
wcmd = wzipexe & " -a " & wtarget & " " & wsource ' Shell 指令
retval = Shell(wcmd, 6) ' Shell 指令传回值
'上面的一大串可写成
'retval = Shell("C:\program files\winzip\WINzip32 -a _
'd:\1.zip d:\1.mdb", 6)
End Sub