使用 C# 讀取 zip 壓縮包解壓文件的方法及注意事項(xiàng)
當(dāng)前位置:點(diǎn)晴教程→知識(shí)管理交流
→『 技術(shù)文檔交流 』
從 .NET Framework 4.5 版本開始,微軟為 .NET 類庫增加了一個(gè)名為 ZipFile 的類型。該類型在 System.IO.Compression 命名空間下,提供創(chuàng)建、解壓縮和打開 zip 存檔的靜態(tài)方法。若要在 .NET Framework 應(yīng)用中使用 ZipFile 類,必須添加對(duì)程序集 System.IO.Compression.FileSystem 的引用。 參考鏈接: https://docs.microsoft.com/zh-cn/dotnet/api/system.io.compression.zipfile?view=net-6.0 使用以下代碼讀取壓縮文件內(nèi)容: 但是,有時(shí)候上述代碼會(huì)不好用。當(dāng)遇到一個(gè)較大的 zip 文件時(shí)可能會(huì)報(bào)錯(cuò): 關(guān)于該錯(cuò)誤,只能搜索到零星的答案,而且大部分都是從國(guó)外網(wǎng)站機(jī)翻的沒有任何參考價(jià)值。 SharpZipLib在 NuGet 上以 zip 為關(guān)鍵詞搜索時(shí),排名第二的是一個(gè)名為 SharpZipLib 的軟件包。 SharpZipLib :https://www.nuget.org/packages/SharpZipLib/ 示例代碼: 在遇到同樣的 zip 包時(shí),上述代碼沒有報(bào)錯(cuò),但結(jié)果仍是錯(cuò)誤的:ZipFile 類型有一個(gè)名為 Count 的屬性,用于獲取該 zip 包中的文件數(shù)量。使用一個(gè)包含 95 萬個(gè)小文件的壓縮包進(jìn)行測(cè)試時(shí),該屬性的取值卻只有 39866 ,也只能獲取到 39866 個(gè)文件。這說明該組件更坑,雖然沒報(bào)錯(cuò)但給了錯(cuò)誤的數(shù)據(jù): 含有 95 萬個(gè)文件的 zip 壓縮包。 DotNetZip排名第三的軟件包是:DotNetZip ,也是一個(gè)比較流行的類庫。 DotNetZip : https://www.nuget.org/packages/DotNetZip/ 他的用法和微軟自帶類庫的用法相似: 經(jīng)測(cè)試,該類庫在處理上文提到的文件時(shí)沒有報(bào)錯(cuò),且獲得了正確的文件內(nèi)容。唯一的遺憾是 Read 方法打開文件時(shí)耗時(shí)較長(zhǎng)。 總結(jié)在處理 zip 文件時(shí),微軟自帶的類庫能滿足大多數(shù)需求。如果遇到報(bào)錯(cuò)的情況,在確認(rèn)源文件正常的情況下可以更換其他類庫讀取。即使在成功讀取后,也需要核對(duì)讀取結(jié)果的正確性:沒有報(bào)錯(cuò),也不代表讀取到的數(shù)據(jù)就是正確的。 另外,為了加快顯示速度,可以將已經(jīng)讀取文件的信息存儲(chǔ)到數(shù)據(jù)庫中,就不需要對(duì)zip壓縮包文件再次臨時(shí)解壓讀取了。 該文章在 2025/2/13 17:37:09 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |