SharpCompress:跨平台的 C# 压缩与解压库

在开发中,处理压缩文件是一个常见的需求。无论是从互联网下载资源、备份数据,还是打包应用程序的输出,压缩和解压功能都扮演着重要的角色。

C#压缩解压文件处理方案

1. 简介

SharpCompress 是一个由 Adam Hathcock 维护的开源 C# 库,提供对多种压缩格式的读写支持。它完全使用 C# 编写,兼容现代 .NET 平台(包括 .NET Standard、.NET Core 和 .NET 5+),适用于 Windows、Linux 和 macOS 系统。

项目地址:https://github.com/adamhathcock/sharpcompress

与其他压缩库相比,SharpCompress 的最大特点是其 广泛支持多种压缩格式,并且可以轻松集成到项目中。此外,它还支持流式处理,适用于大文件或网络传输场景。

2. 支持的压缩格式

SharpCompress 支持以下常见的压缩与归档格式:

  • • ZIP
  • • RAR(含 RAR5)
  • • 7Zip
  • • TAR
  • • GZip
  • • BZip2
  • • LZip
  • • XZ

支持以下格式的 写入

  • • ZIP
  • • TAR
  • • GZip
  • • BZip2
  • • LZip

对于需要长期归档和流式处理的场景,推荐使用 GZip、BZip2 或 LZip,因其格式简洁且易于流式解析。

3. 安装与引入

通过 NuGet 包管理器安装

Install-Package SharpCompress

引用命名空间即可开始使用

using SharpCompress.Archives;

using SharpCompress.Common;

using System.IO;

4. 基本用法

4.1 解压 ZIP 文件

一个简单的 ZIP 文件解压示例

using (var archive = ArchiveFactory.Open("example.zip"))

{

foreach (var entry in archive.Entries)

{

if (!entry.IsDirectory)

{

entry.WriteToDirectory("output_directory", new ExtractionOptions()

{

ExtractFullPath = true,

Overwrite = true

});

}

}

}

4.2 创建 ZIP 文件

创建 ZIP 文件

using (var archive = ArchiveFactory.CreateWritableArchive(ArchiveType.Zip, File.Create("new_archive.zip")))

{

archive.AddAllFromDirectory("source_directory");

}

4.3 处理 RAR 文件(仅限读取)

由于 RAR 格式是专有格式,SharpCompress 只支持读取 RAR 文件:

using (var archive = ArchiveFactory.Open("example.rar"))

{

foreach (var entry in archive.Entries)

{

if (!entry.IsDirectory)

{

entry.WriteToDirectory("output_directory", new ExtractionOptions()

{

ExtractFullPath = true,

Overwrite = true

});

}

}

}

5. 高级特性

5.1 流式处理

SharpCompress 支持从 Stream 中读取和写入压缩文件,这使得它可以用于网络请求、内存操作等场景

using (var stream = new FileStream("example.zip", FileMode.Open))

using (var archive = ArchiveFactory.Open(stream))

{

// 处理解压逻辑

}

5.2 加密支持

某些压缩格式(如 ZIP)支持加密压缩包。SharpCompress 允许你在打开加密压缩包时提供密码

using (var archive = ArchiveFactory.Open("encrypted.zip", new ReaderOptions { Password = "password" }))

{

// 解压逻辑

}

5.3 自定义提取选项

通过 ExtractionOptions,你可以控制是否覆盖现有文件、是否提取完整路径等。

相关推荐
basketball6167 小时前
C++ NULL 和 nullptr 区别 以及 nullptr 的核心实现
java·开发语言·c++
旺仔来了7 小时前
不联网的Linux下部署python环境
linux·开发语言·python
之歆8 小时前
Day16_JavaScript 轮播图与事件工程实战(下篇)
服务器·开发语言·前端·javascript·网络·性能优化
会Tk矩阵群控的小木8 小时前
云控系统在TikTok多账号管理中的核心应用与技术实现
开发语言·php·开源软件·个人开发·tk矩阵
摇滚侠9 小时前
Java 零基础全套教程,反射机制,笔记 187-188
java·开发语言·笔记
Ulyanov9 小时前
用声明式语法重新定义Python桌面UI:QML+PySide6现代开发入门(一)
开发语言·python·算法·ui·系统仿真·雷达电子对抗仿真
超梦dasgg9 小时前
Java 生产环境第三方对接安全保障方案
java·开发语言·安全
傻啦嘿哟9 小时前
降低首字延迟(TTFB):专线节点与TCP Fast Open的配置
开发语言·php
z落落9 小时前
C#参数区别
java·算法·c#
影寂ldy9 小时前
C#随机数
开发语言·c#