Sample code for 30+ languages & platforms
VBScript

Append Files to an Existing ZIP Archive Using QuickAppend

See more Zip Examples

Demonstrates how to use the QuickAppend method to append additional files to an existing ZIP archive.

Unlike methods that rewrite the entire ZIP archive, QuickAppend modifies the existing ZIP in-place by appending new entries directly to the end of the archive.

Existing ZIP entries are not recompressed or rewritten, making QuickAppend the fastest and most efficient way to add files to a large pre-existing ZIP archive.

Chilkat VBScript Downloads

VBScript
Dim fso, outFile
Set fso = CreateObject("Scripting.FileSystemObject")
'Create a Unicode (utf-16) output text file.
Set outFile = fso.CreateTextFile("output.txt", True, True)

success = 0

set zip = CreateObject("Chilkat.Zip")

' ------------------------------------------------------------
' Initialize a new Zip object.
' 
' NewZip resets the Zip object to a new and empty state.
' It does NOT immediately create or write a .zip file.
' 
' The filename passed to NewZip is not used by QuickAppend,
' but NewZip is still useful because it initializes the
' Zip object to an empty state.
success = zip.NewZip("notUsed.zip")
If (success = 0) Then
    outFile.WriteLine(zip.LastErrorText)
    WScript.Quit
End If

' ------------------------------------------------------------
' Add a reference to a local filesystem file.
' 
' AddFile does NOT immediately read or compress the file.
' Instead, it adds a reference to the file that will later
' be processed when QuickAppend is called.
' 
' The file being referenced is:
' 
'     c:/temp/files/something.dat
' 
saveExtraPath = 0

success = zip.AddFile("c:/temp/files/something.dat",saveExtraPath)

If (success = 0) Then
    outFile.WriteLine(zip.LastErrorText)
    WScript.Quit
End If

' Because saveExtraPath = 0,
' the file will be stored in the ZIP as:
' 
'     something.dat
' 

' ------------------------------------------------------------
' Append the referenced files to an existing ZIP archive.
' 
' QuickAppend opens the existing ZIP archive:
' 
'     c:/temp/zips/preExisting.zip
' 
' The referenced files are then:
' 
'   * Read from the local filesystem
'   * Compressed as needed
'   * Appended to the existing ZIP archive
' 
success = zip.QuickAppend("c:/temp/zips/preExisting.zip")
If (success = 0) Then
    outFile.WriteLine(zip.LastErrorText)
    WScript.Quit
End If

outFile.WriteLine("Files appended successfully.")
outFile.WriteLine("")

' ------------------------------------------------------------
' Additional files, directory trees, or in-memory data
' can be added before calling QuickAppend.
' 
' For example:
' 
'     AddFile
'     AppendFiles
'     AppendFilesEx
'     AddString
'     AddBd
'     AddSb
' 
' Whatever entries are currently referenced by the Zip object
' are appended to the existing ZIP archive when QuickAppend
' is called

outFile.Close