Recursively Add Files to a ZIP Using AppendFilesEx
See more Zip Examples
This example demonstrates how to use the AppendFilesEx method
to recursively add files from the local filesystem to a ZIP archive while
controlling how directory paths and special filesystem attributes are handled.
The example:
- Recursively scans a directory tree for files
-
Demonstrates how the
saveExtraPathargument affects the paths stored within the ZIP archive - Includes hidden files
- Excludes files having the Windows System attribute
- Shows how local filesystem paths are transformed into ZIP entry paths
The AppendFilesEx method adds references to files in the local
filesystem. The files are not actually read or compressed until a
Write* method is called.
This method is cross-platform and works on Windows, macOS, Linux, Android, iOS, and other supported operating systems.
Some arguments are Windows-specific:
-
archiveOnlyapplies only to the Windows Archive attribute -
includeSystemapplies only to the Windows System attribute
On non-Windows operating systems, these Windows-specific options are simply ignored.
Suppose the local filesystem contains the following directory tree:
c:/project/files/docs/readme.txt
c:/project/files/docs/manual.pdf
c:/project/files/images/logo.png
And suppose the following call is made:
zip.AppendFilesEx("c:/project/files",_TRUE_,saveExtraPath,_FALSE_,_TRUE_,_FALSE_);
If saveExtraPath = _TRUE_, the following paths are stored
in the ZIP archive:
project/files/docs/readme.txt
project/files/docs/manual.pdf
project/files/images/logo.png
In this case, the extra leading path information from the filePattern is preserved in the ZIP.
If saveExtraPath = _FALSE_, the following paths are stored
in the ZIP archive instead:
docs/readme.txt
docs/manual.pdf
images/logo.png
In this case, the leading project/files portion of the path
is not stored in the ZIP archive.
Chilkat Visual Basic 6.0 Downloads
Dim success As Long
success = 0
Dim zip As New ChilkatZip
success = zip.NewZip("appendFilesEx.zip")
If (success = 0) Then
Debug.Print zip.LastErrorText
Exit Sub
End If
' Recursively include all files beneath c:/project/files.
Dim recurse As Long
recurse = 1
'
' The saveExtraPath argument controls whether the extra leading path
' information from the filePattern is included in the stored ZIP paths.
'
' For example, suppose the local filesystem contains:
'
' c:/project/files/docs/readme.txt
' c:/project/files/docs/manual.pdf
' c:/project/files/images/logo.png
'
' And suppose AppendFilesEx is called with:
'
' "c:/project/files"
'
' If saveExtraPath = 1, the ZIP stores:
'
' project/files/docs/readme.txt
' project/files/docs/manual.pdf
' project/files/images/logo.png
'
' In this case, the extra path information from the filePattern is preserved.
'
' ----------------------------------------------------------------
'
' If saveExtraPath = 0, the ZIP stores paths relative to the
' directory specified by the filePattern:
'
' docs/readme.txt
' docs/manual.pdf
' images/logo.png
'
' In this case, the leading "project/files" path is not stored in the ZIP.
' ----------------------------------------------------------------
' Preserve extra path information within the ZIP archive.
Dim saveExtraPath As Long
saveExtraPath = 1
' Do not require the Windows archive attribute.
Dim archiveOnly As Long
archiveOnly = 0
' Include hidden files.
Dim includeHidden As Long
includeHidden = 1
' Exclude files having the Windows System attribute.
Dim includeSystem As Long
includeSystem = 0
success = zip.AppendFilesEx("c:/project/files",recurse,saveExtraPath,archiveOnly,includeHidden,includeSystem)
If (success = 0) Then
Debug.Print zip.LastErrorText
Exit Sub
End If
' Write the ZIP archive to disk.
success = zip.WriteZipAndClose()
If (success = 0) Then
Debug.Print zip.LastErrorText
Exit Sub
End If
Debug.Print "ZIP archive created successfully."