![]() |
Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Visual Basic 6.0) Decompress Large Text File in BlocksDecompresses a large text file in blocks, and compares the restored (decompressed) file with the original to make sure it's correct. Note: This example requires Chilkat v11.0.0 or greater.
Dim success As Long success = 0 ' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' First, let's compress a text file. ' We'll then decompress in blocks, and compare the decompressed with the original file. ' Compress a text file: Dim compress As New ChilkatCompression compress.Algorithm = "deflate" success = compress.CompressFile("qa_data/hamlet.xml","qa_data/hamlet_compressed.dat") If (success = 0) Then Debug.Print compress.LastErrorText Exit Sub End If Dim fac As New CkFileAccess ' Examine the uncompressed and compressed sizes: Dim originalPath As String originalPath = "qa_data/hamlet.xml" ' Note: The FileSize method returns a signed 32-bit integer. If the file is potentially larger than 2GB, call FileSizeStr instead to return ' the size of the file as a string, then convert to an integer value. Debug.Print "uncompressed size: " & fac.FileSize(originalPath) Debug.Print "compressed size: " & fac.FileSize("qa_data/hamlet_compressed.dat") ' Decompress in blocks.. Dim facSrc As New CkFileAccess Dim facDest As New CkFileAccess success = facSrc.OpenForRead("qa_data/hamlet_compressed.dat") ' If we compress in 32K chunks, find out how many blocks there will be. Dim blockSize As Long blockSize = 32768 Dim numBlocks As Long numBlocks = facSrc.GetNumBlocks(blockSize) ' Open an output file for the decompressed data. Dim restoredPath As String restoredPath = "qa_output/hamlet_restored.xml" success = facDest.OpenForWrite(restoredPath) If (success = 0) Then Debug.Print facDest.LastErrorText Exit Sub End If Dim decompressedStr As String Dim compressedBytes() As Byte ' Assuming numBlocks > 1 compress.FirstChunk = 1 compress.LastChunk = 0 Dim i As Long i = 0 Do While i < numBlocks compressedBytes = facSrc.ReadBlock(i,blockSize) decompressedStr = compress.DecompressString(compressedBytes) success = facDest.AppendText(decompressedStr,"utf-8") i = i + 1 compress.FirstChunk = 0 If (i = (numBlocks - 1)) Then compress.LastChunk = 1 End If Loop facSrc.FileClose facDest.FileClose ' Examine the size of the restored file. Debug.Print "restored size: " & fac.FileSize(restoredPath) ' Compare the contents of the original with the restored. Dim bEqualContents As Long bEqualContents = fac.FileContentsEqual(restoredPath,originalPath) Debug.Print "Contents Equal: " & bEqualContents |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.