Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(VB.NET UWP/WinRT) 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.
' 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 Chilkat.Compression compress.Algorithm = "deflate" Dim success As Boolean = Await compress.CompressFileAsync("qa_data/hamlet.xml","qa_data/hamlet_compressed.dat") If (success <> True) Then Debug.WriteLine(compress.LastErrorText) Exit Sub End If Dim fac As New Chilkat.FileAccess ' Examine the uncompressed and compressed sizes: Dim originalPath As String = "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.WriteLine("uncompressed size: " & fac.FileSize(originalPath)) Debug.WriteLine("compressed size: " & fac.FileSize("qa_data/hamlet_compressed.dat")) ' Decompress in blocks.. Dim facSrc As New Chilkat.FileAccess Dim facDest As New Chilkat.FileAccess facSrc.OpenForRead("qa_data/hamlet_compressed.dat") ' If we compress in 32K chunks, find out how many blocks there will be. Dim blockSize As Integer = 32768 Dim numBlocks As Integer = facSrc.GetNumBlocks(blockSize) ' Open an output file for the decompressed data. Dim restoredPath As String = "qa_output/hamlet_restored.xml" success = facDest.OpenForWrite(restoredPath) If (success <> True) Then Debug.WriteLine(facDest.LastErrorText) Exit Sub End If Dim decompressedStr As String Dim compressedBytes() As Byte Dim i As Integer = 0 While i < numBlocks compressedBytes = facSrc.ReadBlock(i,blockSize) If (i = 0) Then decompressedStr = Await compress.BeginDecompressStringAsync(compressedBytes) Else decompressedStr = Await compress.MoreDecompressStringAsync(compressedBytes) End If facDest.AppendText(decompressedStr,"utf-8") i = i + 1 End While ' At the very end, flush any remaining content, if any. decompressedStr = Await compress.EndDecompressStringAsync() facDest.AppendText(decompressedStr,"utf-8") facSrc.FileClose() facDest.FileClose() ' Examine the size of the restored file. Debug.WriteLine("restored size: " & fac.FileSize(restoredPath)) ' Compare the contents of the original with the restored. Dim bEqualContents As Boolean = fac.FileContentsEqual(restoredPath,originalPath) Debug.WriteLine("Contents Equal: " & bEqualContents) |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.