純vbs實(shí)現(xiàn)zip壓縮與unzip解壓縮函數(shù)代碼
更新時(shí)間:2011年01月21日 23:35:45 作者:
用VBS解壓ZIP文件,網(wǎng)上搜到的多數(shù)是調(diào)用WinRAR,一點(diǎn)技術(shù)含量也沒(méi)有。聽(tīng)說(shuō)可以用純vbs實(shí)現(xiàn),特整理給大家,已經(jīng)過(guò)測(cè)試。喜歡的朋友可以測(cè)試下。
壓縮代碼:
復(fù)制代碼 代碼如下:
Zip "D:\test.iso", "D:\test.zip"
Zip "D:\test", "D:\test.zip"
Msgbox "OK"
Sub Zip(ByVal mySourceDir, ByVal myZipFile)
Set fso = CreateObject("Scripting.FileSystemObject")
If fso.GetExtensionName(myZipFile) <> "zip" Then
Exit Sub
ElseIf fso.FolderExists(mySourceDir) Then
FType = "Folder"
ElseIf fso.FileExists(mySourceDir) Then
FType = "File"
FileName = fso.GetFileName(mySourceDir)
FolderPath = Left(mySourceDir, Len(mySourceDir) - Len(FileName))
Else
Exit Sub
End If
Set f = fso.CreateTextFile(myZipFile, True)
f.Write "PK" & Chr(5) & Chr(6) & String(18, Chr(0))
f.Close
Set objShell = CreateObject("Shell.Application")
Select Case Ftype
Case "Folder"
Set objSource = objShell.NameSpace(mySourceDir)
Set objFolderItem = objSource.Items()
Case "File"
Set objSource = objShell.NameSpace(FolderPath)
Set objFolderItem = objSource.ParseName(FileName)
End Select
Set objTarget = objShell.NameSpace(myZipFile)
intOptions = 256
objTarget.CopyHere objFolderItem, intOptions
Do
WScript.Sleep 1000
Loop Until objTarget.Items.Count > 0
End Sub
解壓縮代碼:
復(fù)制代碼 代碼如下:
UnZip "D:\test.iso", "D:\test.zip"
Msgbox "OK"
Sub CopyFolder(ByVal mySourceDir, ByVal myTargetDir)
Set fso = CreateObject("Scripting.FileSystemObject")
If NOT fso.FolderExists(mySourceDir) Then
Exit Sub
ElseIf NOT fso.FolderExists(myTargetDir) Then
fso.CreateFolder(myTargetDir)
End If
Set objShell = CreateObject("Shell.Application")
Set objSource = objShell.NameSpace(mySourceDir)
Set objFolderItem = objSource.Items()
Set objTarget = objShell.NameSpace(myTargetDir)
intOptions = 256
objTarget.CopyHere objFolderItem, intOptions
End Sub
用VBS解壓ZIP文件,網(wǎng)上搜到的多數(shù)是調(diào)用WinRAR,一點(diǎn)技術(shù)含量也沒(méi)有。Google一下“VBS 解壓ZIP”,第二是搜搜問(wèn)問(wèn)“vbs實(shí)現(xiàn)解壓縮zip文件”,滿意答案是“所以想用vbs來(lái)解壓這兩種格式的文件,至少要有兩種命令行解壓工具,否則是絕對(duì)不可以的”。絕對(duì)不可以的,回答的人好自信啊,笑而不語(yǔ)~
原文:http://demon.tw/programming/vbs-zip-file.html
http://demon.tw/programming/vbs-unzip-file.html
相關(guān)文章
VBS教程:函數(shù)-TypeName 函數(shù)
VBS教程:函數(shù)-TypeName 函數(shù)...2006-11-11用VBS實(shí)現(xiàn)音樂(lè)播放的多個(gè)代碼小結(jié)
用VBS實(shí)現(xiàn)音樂(lè)播放的多個(gè)代碼,下面根據(jù)網(wǎng)上的一些文章進(jìn)行了整理說(shuō)明,需要的朋友可以參考下。2011-02-02VBS讀取配置文件配置項(xiàng)的實(shí)現(xiàn)代碼
今天寫代碼的時(shí)候需要用到vbs獲取文件配置項(xiàng),不用放數(shù)據(jù)庫(kù)里面,要不增刪改查都要做一篇,本身功能就簡(jiǎn)單,這里就為大家分享一下實(shí)現(xiàn)代碼,需要的朋友可以參考下2019-09-09vbs 定時(shí)刪除功能實(shí)現(xiàn)代碼
這篇文章主要介紹了vbs 定時(shí)刪除功能實(shí)現(xiàn)代碼,需要的朋友可以參考下2014-05-05VBS實(shí)現(xiàn)將當(dāng)前時(shí)間轉(zhuǎn)換成UTC時(shí)間
這篇文章主要介紹了VBS實(shí)現(xiàn)將當(dāng)前時(shí)間轉(zhuǎn)換成UTC時(shí)間,十分的簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-05-05