Bianchi928
asked on
Zip selected files
I have this script that checks for selected files in "strsource". From there I need to be able to zip these files to "strdest". I really don't know how to do that.
' Isalogs & Export are shared folders
Dim Strdate, StrSource, StrDest, Fso, objFolder, colFiles, objFile, strFile
Set fso = CreateObject("Scripting.Fi leSystemOb ject")
set wshshell = wscript.createobject("wscr ipt.shell" )
strDate = Date()
strSource = "\\isaserver\isalogs\"
strDest = "\\isaserver\export\"
If fso.FolderExists(strSource ) Then
Set objFolder = fso.GetFolder(strSource)
Set colFiles = objFolder.Files
End if
For Each strFile in colFiles
if InStr(strfile.datecreated, strdate) > 0 then
??????????????????
end if
Next
' Isalogs & Export are shared folders
Dim Strdate, StrSource, StrDest, Fso, objFolder, colFiles, objFile, strFile
Set fso = CreateObject("Scripting.Fi
set wshshell = wscript.createobject("wscr
strDate = Date()
strSource = "\\isaserver\isalogs\"
strDest = "\\isaserver\export\"
If fso.FolderExists(strSource
Set objFolder = fso.GetFolder(strSource)
Set colFiles = objFolder.Files
End if
For Each strFile in colFiles
if InStr(strfile.datecreated,
??????????????????
end if
Next
This is bad style:
I take it the target ZIP files do not exist yet, and you want to create a single ZIP for each source file. I'm not clear about whether you want to copy or move the files, however.
if InStr(strfile.datecreated, strdate) > 0 then
You should always compare dates with dates. Using string comparision provokes issues.I take it the target ZIP files do not exist yet, and you want to create a single ZIP for each source file. I'm not clear about whether you want to copy or move the files, however.
' Isalogs & Export are shared folders
Dim dt, strSrc, strDst, fso, srcFile, dstFile
dt = Date()
strSrc = "\\isaserver\isalogs\"
strDst = "\\isaserver\export\"
Set fso = CreateObject("Scripting.FileSystemObject")
set shApp= CreateObject("Shell.Application")
For Each srcFile in fso.GetFolder(strSrc).Files
If srcFile.DateCreated >= dt Then
dstFile = strDst + srcFile.BaseName + '.zip'
If not fso.FileExists(dstFile) Then
With fso.CreateTextFile(dstFile, True)
.Write "PK" + chr(5) + char(6) + String(18, chr(0))
End With
shApp.NameSpace(dstFile).CopyHere srcFile.FullName
WScript.Sleep 250
End If
Next
This copies the files. The sleep is recommended as the compression is done in the background, and the code not waiting for completion. If you do not wait, you'll start a compression thread for each file (almost) simultanously, slowing down all file operations.
Ah, WinRAR, but you do not need it here, as you can see.
ASKER
Hi,
Thanks for your answer...I have done some changes to your script as it was coming with some errors. I also modifi3ed the date check for testing purposes. Now I'm getting an error message
Object required shApp.NameSpace(...).
Also , I forgot to say that I want all selected file to be zipped together.
I will really appreciate if I can also have the script lines if I wanted to use winrar.
Thanks
Cheers
Dim dt, strSrc, strDst, fso, srcFile, dstFile
dt = Date() - 1
strSrc = "\\isaserver\isalogs\"
strDst = "\\isaserver\export\"
Newname = replace(date,"/","")
ZipFile = "Isalogs" & newname & ".zip"
Set fso = CreateObject("Scripting.Fi leSystemOb ject")
set shApp= CreateObject("Shell.Applic ation")
For Each srcFile in fso.GetFolder(strSrc).File s
If srcFile.DateCreated >= dt Then
If not fso.FileExists(zipfile) Then
With fso.CreateTextFile(strdst & zipfile, True)
.Write "PK" + chr(5) + chr(6) + String(18, chr(0))
End With
End if
shApp.NameSpace(zipFile).C opyHere srcFile.Name
WScript.Sleep 250
End If
Next
Thanks for your answer...I have done some changes to your script as it was coming with some errors. I also modifi3ed the date check for testing purposes. Now I'm getting an error message
Object required shApp.NameSpace(...).
Also , I forgot to say that I want all selected file to be zipped together.
I will really appreciate if I can also have the script lines if I wanted to use winrar.
Thanks
Cheers
Dim dt, strSrc, strDst, fso, srcFile, dstFile
dt = Date() - 1
strSrc = "\\isaserver\isalogs\"
strDst = "\\isaserver\export\"
Newname = replace(date,"/","")
ZipFile = "Isalogs" & newname & ".zip"
Set fso = CreateObject("Scripting.Fi
set shApp= CreateObject("Shell.Applic
For Each srcFile in fso.GetFolder(strSrc).File
If srcFile.DateCreated >= dt Then
If not fso.FileExists(zipfile) Then
With fso.CreateTextFile(strdst & zipfile, True)
.Write "PK" + chr(5) + chr(6) + String(18, chr(0))
End With
End if
shApp.NameSpace(zipFile).C
WScript.Sleep 250
End If
Next
For the integrated ZIP folder feature you need to use full paths; zipfile is only the filename. Further you used date instead of dt
Dim dt, strSrc, strDst, fso, srcFile, dstFile, ZipFile
dt = Date() - 1
strSrc = "\\isaserver\isalogs\"
strDst = "\\isaserver\export\"
ZipFile = strDst + "Isalogs" + replace(dt,"/","") + ".zip"
Set fso = CreateObject("Scripting.FileSystemObject")
set shApp= CreateObject("Shell.Application")
For Each srcFile in fso.GetFolder(strSrc).Files
If srcFile.DateCreated >= dt Then
If not fso.FileExists(zipfile) Then
With fso.CreateTextFile(zipfile, True)
.Write "PK" + chr(5) + chr(6) + String(18, chr(0))
End With
End if
shApp.NameSpace(zipFile).CopyHere srcFile.FullName
WScript.Sleep 250
End If
Next
Using WinRAR would look like (you might have to tweak the options):Dim dt, strSrc, strDst, fso, srcFile, dstFile, ZipFile, shell
dt = Date() - 1
strSrc = "\\isaserver\isalogs\"
strDst = "\\isaserver\export\"
ZipFile = strDst + "Isalogs" + replace(dt,"/","") + ".zip"
Set fso = CreateObject("Scripting.FileSystemObject")
set shell= CreateObject("WScript.Shell")
For Each srcFile in fso.GetFolder(strSrc).Files
If srcFile.DateCreated >= dt Then strFiles = strFiles + " " + srcFile.FullName
Next
If strFile != "" Then
shell.Run "winrar a -afzip " + ZipFile + strFiles
End If
ASKER
Qlemo,
In the revised script, I have a problem with Line 18
Object doesn't support the property or method of ;'Fullname'
In the revised script, I have a problem with Line 18
Object doesn't support the property or method of ;'Fullname'
ASKER CERTIFIED SOLUTION
membership
This solution is only available to members.
To access this solution, you must be a member of Experts Exchange.
ASKER
Good job. Thanks a lot
ASKER
Cool man. Thanks again
Cheers
Cheers
ASKER