在.NET中實(shí)現(xiàn)文件或文件目錄壓縮和解壓可以通過多種方式來完成,包括使用原生方法(System.IO.Compression命名空間中的類)和第三方庫(如:SharpZipLib、SharpCompress、K4os.Compression.LZ4等)。本文我們主要講的是如何使用.NET原生方法System.IO.Compression命名空間中的類來對(duì)文件和文件夾進(jìn)行壓縮或解壓縮(壓縮格式.zip文件格式)。
包含為流提供基本壓縮和解壓縮服務(wù)的類。
用來指示壓縮操作是強(qiáng)調(diào)速度還是強(qiáng)調(diào)壓縮大小的值。
枚舉類型 | 枚舉值 | 作用說明 |
Optimal | 0 | 壓縮操作應(yīng)以最佳方式平衡壓縮速度和輸出大小。 |
Fastest | 1 | 即使結(jié)果文件未可選擇性地壓縮,壓縮操作也應(yīng)盡快完成。 |
NoCompression | 2 | 該文件不應(yīng)執(zhí)行壓縮。 |
SmallestSize | 3 | 壓縮操作應(yīng)創(chuàng)建盡可能小的輸出,即使該操作需要更長(zhǎng)的時(shí)間才能完成。 |
用來與 zip 存檔條目進(jìn)行交互的值。
枚舉類型 | 枚舉值 | 作用說明 |
Read | 0 | 只允許讀取存檔項(xiàng)。 |
Create | 1 | 只允許創(chuàng)建新的存檔項(xiàng)。 |
Update | 2 | 允許對(duì)存檔項(xiàng)執(zhí)行讀取和寫入操作。 |
創(chuàng)建名為:FileCompDecompExercise的控制臺(tái)應(yīng)用。
圖片
圖片
圖片
static void Main(string[] args) { var sourceFilePath = @"./MySourceFile.xls"; //指定要壓縮的文件路徑(先創(chuàng)建對(duì)應(yīng).xls文件) var zipSourceFilePath = @"./OutputFolder/ZipSourceFilePath.zip"; //壓縮后文件存放路徑 //指定文件壓縮為zip文件 CompressZipFile(sourceFilePath, zipSourceFilePath); Console.WriteLine("操作完成"); } /// <summary> /// 指定文件壓縮為zip文件 /// </summary> /// <param name="sourceFilePath">指定要壓縮的文件路徑</param> /// <param name="zipFilePath">指定壓縮后的zip文件路徑</param> public static void CompressZipFile(string sourceFilePath, string zipFilePath) { //確保指定的路徑中的目錄存在 DirectoryInfo directoryInfo = new DirectoryInfo(zipFilePath); if (directoryInfo.Parent != null) { directoryInfo = directoryInfo.Parent; } if (!directoryInfo.Exists) { directoryInfo.Create(); } // 創(chuàng)建一個(gè)新的 Zip 存檔并向其中添加指定的文件 using (ZipArchive archive = ZipFile.Open(zipFilePath, ZipArchiveMode.Update)) { archive.CreateEntryFromFile(sourceFilePath, Path.GetFileName(sourceFilePath)); } Console.WriteLine("文件壓縮完成"); }
圖片
static void Main(string[] args) { var sourceDirectory = @"./ZipFileDirectory";//指定壓縮的文件目錄(先在對(duì)應(yīng)位置創(chuàng)建好) var zipFilePath = @"./OutputFolder/Archive.zip"; //壓縮后文件存放路徑 CompressZipFileDirectory(sourceDirectory, zipFilePath); Console.WriteLine("操作完成"); } /// <summary> /// 指定文件目錄壓縮為zip文件 /// </summary> /// <param name="sourceDirectory">指定壓縮的文件目錄</param> /// <param name="zipFilePath">壓縮后文件存放路徑</param> public static void CompressZipFileDirectory(string sourceDirectory, string zipFilePath) { //確保指定的路徑中的目錄存在 DirectoryInfo directoryInfo = new DirectoryInfo(zipFilePath); if (directoryInfo.Parent != null) { directoryInfo = directoryInfo.Parent; } if (!directoryInfo.Exists) { directoryInfo.Create(); } //創(chuàng)建一個(gè)新的 .zip 文件并將文件夾內(nèi)容壓縮進(jìn)去 ZipFile.CreateFromDirectory(sourceDirectory, zipFilePath, CompressionLevel.Optimal, false); Console.WriteLine("文件目錄壓縮完成"); }
圖片
static void Main(string[] args) { var zipFilePath = @"./OutputFolder/Archive.zip"; //壓縮后文件存放路徑 string extractPath = @"./OutputFolder"; // 解壓目標(biāo)文件夾路徑 //解壓.zip文件到目標(biāo)文件夾 ExtractZipFile(zipFilePath, extractPath); Console.WriteLine("操作完成"); } /// <summary> /// 解壓.zip文件到目標(biāo)文件夾 /// </summary> /// <param name="zipFilePath">要解壓的.zip文件路徑</param> /// <param name="extractPath">解壓目標(biāo)文件夾路徑</param> public static void ExtractZipFile(string zipFilePath, string extractPath) { if (!Directory.Exists(extractPath)) { Directory.CreateDirectory(extractPath); } // 提取 .zip 文件到指定文件夾 ZipFile.ExtractToDirectory(zipFilePath, extractPath); Console.WriteLine("文件解壓完成"); }
圖片
https://github.com/YSGStudyHards/DotNetExercises/tree/master/FileCompDecompExercise
本文鏈接:http://www.www897cc.com/showinfo-26-95164-0.html.NET使用原生方法實(shí)現(xiàn)文件壓縮和解壓
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。郵件:2376512515@qq.com
上一篇: Apereo CAS SSO單點(diǎn)系統(tǒng)的 OAuth2/OpenID Connect集成問題