- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试使用 DotNetZip 库解压缩文件。
该文件包含带有丹麦字符 (æøåÆØÅ) 的文件夹和文件。
TotalCommander、7Zip、Windows 自己的 zip 都可以正确提取文件,但 DotNetZip 库会破坏丹麦语字符。
例如:File_æøåÆØÅ.txt
变成 File_æ¢åÆ¥Å.txt
代替 aø
它包含一个 ¢
。代替 Ø
它包含一个 ¥
。
代码:
using (var zipFile = ZipFile.Read(@"File_æøåÆØÅ.zip"))
{
zipFile.ExtractAll(@"File_æøåÆØÅ",
ExtractExistingFileAction.OverwriteSilently);
}
我使用的是默认编码(“da-DK”文化),我尝试过其他编码,如 UTF8 等。
如何解压缩包含丹麦字 rune 件名的文件?
最佳答案
要处理该 zip 文件,请在读取 zip 时明确指定丹麦语代码页:
var encoding = System.Text.Encoding.GetEncoding("da-DK");
using (var zipFile = ZipFile.Read(@"File_æøåÆØÅ.zip", encoding)) {
zipFile.ExtractAll(@"File_æøåÆØÅ",
ExtractExistingFileAction.OverwriteSilently);
}
您需要明确执行此操作的原因:
zip 规范允许对 zip 文件中的文件名和注释使用两种文本编码:IBM437 和 UTF8。当使用这些兼容编码中的任何一种时,zipfile 元数据都会明确指定它。 DotNetZip 或任何库都可以自信地使用 zip 文件中指定的编码。
zip 文件无法指定不是这两种编码之一的编码。 zip 规范不提供执行此操作的方法。一些 zip 库或工具构建的 zip 文件不符合这方面的规范; zip 文件使用文本编码,如“da-DK”或 CP950 或其他。严格来说它们不符合规范,但工具仍然构建它们。像这样的 Zip 文件并不少见。
在这种情况下,一些库或工具会猜测 zip 文件中使用的编码与机器上的默认编码相同。这不安全,也不能保证有效,但它是一种适用于小情况的假设——zip 文件是由本地机器上的不兼容库或工具创建的。如果您使用默认(不兼容)文本编码构建一个 zipfile,然后将其从 Stokholm 发送到上海,则在读取时使用“假定默认编码”策略将失败。
DotNetZip 没有做出这样的假设。在 zipfile 使用不兼容的文本编码的情况下,zipfile 中没有关于使用哪种编码的指示,因此 DotNetZip 使用标准编码 - IBM437 - 来读取文件。 DNZ 无法知道这是“错误的”。如果您想覆盖该行为,您需要使用接受不同编码的 ZipFile.Read() 方法。
这在 DotNetZip documentation 中都有描述。 ,特别是在 ZipFile.ProvisionalAlternateEncoding属性(property)。
关于c# - 使用 DotNetZip 库解压非 ASCII 字符的文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4654860/
由于我对 Visual Studio 很陌生,所以这个问题可能听起来有点愚蠢: 如何安装 DotNetZip 库?我正在使用适用于 Windows 桌面的 Visual Studio Express
我有一个非常简单的程序,使用 DotNetZip(最新版本)和 C#.Net、VS2010。当它尝试保存已压缩的文件时,它已开始挂起。没有错误消息,什么也没有。它运行了很长一段时间,然后突然开始出现这
我使用 DotNetZip 库进行了快速测试,该库打开一个充满 .bmp 文件的 zip 文件并将它们转换为 .jpg 格式。 在此之前,我将所有文件写入一个文件夹,转换它们,保存 jpg 文件,然后
我正在使用 DotNetZip从 zip 文件中提取文件的库。 using(ZipFile zip = ZipFile.Read(zipLocation)) { foreach (ZipEnt
嗯! using (ZipFile zip = new ZipFile()) { // add this map file into the "images" directory in
我正在尝试压缩一堆文件并通过流使数据可用。 我希望内存占用尽可能小。 我的想法是实现一个 Stream,其中我有一堆 FileStream 对象作为数据成员。当我的 Stream 上的 Read 方法
我正在使用 C# 进行开发,并使用 Dotnetzip 的源代码在一个文件中获取应用程序。 但是在运行时,我得到了异常: System.OverflowException: Arithmetic op
我正在尝试创建一个将流式传输给用户的 DotNetZip zip 文件。在 zip 文件中,我插入了两个内存流。但是由于某种原因,当我打开 zip 文件时,它是空的。我查看了文档,发现几乎没有帮助。我
我正在使用 DotNetZip。当我正常归档具有英文名称的文件时。但是当我在结果存档中使用错误的文件名存档带有俄罗斯名称的文件时。有人说那个字符串 ZipConstants.DefaultCodePa
这个问题解决了。我的错误是在我的第二个代码块中,我使用的是 SaveProgress 而不是 ExtractProgress,并且在设置事件处理程序之前我使用的是 Zip.ExtractAll。感谢B
string desktop = Environment.GetFolderPath(Environment.SpecialFolder.Desktop); public
类似的问题都不是我要找的! 下面的代码有什么问题?files是文件内容的文本数组,fileNames是对应的文件名数组。 这段代码总是在倒数第二行的 Save 方法失败,但我不明白为什么流会被关闭!
我已经下载了 DotNetZip from codeplex我完全不知道下一步该怎么做。 我想提取一个.zip 存档 我知道我用的是这样的 string zipToUnpack = "C1P3SML.
当我使用 DotNetZip 创建存档时,它会将文件名中的国家字母更改为其对应的英文字母。 (Ł --> L) 这对我来说真的很糟糕,因为它破坏了我的备份应用程序。我尝试将编码更改为utf8、1252
我有一个在任务中执行压缩解压缩的方法。现在我想要取消操作的能力。但是当我调用 Cancel() 方法时,一切似乎都立即停止并且 while 永远运行: public class OsiSourceZi
我通过以下方式使用 dotnet zip: using (ZipFile zip = new ZipFile(@"E:\test2.zip")) { zip.ParallelDeflate
我正在尝试使用 DotNetZip 库将文件提取到当前工作目录的方法,虽然我似乎无法做到这一点,但它需要一个文件路径: private void unzipfiles() { using (v
问候.... 我正在用 c# 3.5 编写一个备份程序,使用的是最新的 DotNetZip。该程序的基础是在服务器上指定一个位置和跨区 zip 文件的最大大小,然后运行。从那里它应该遍历给定位置的所有
我无法想象这很难做到,但我一直无法让它发挥作用。我有一个文件类,它只存储我要压缩的文件的位置、目录和名称。我正在压缩的文件存在于磁盘上,因此 FileLocation 是完整路径。磁盘上不存在 Zip
我正在使用 DotNetZip 将文件从 MemoryStream 添加到 zip 文件,然后将该 zip 保存为 MemoryStream,以便我可以将其作为附件通过电子邮件发送.下面的代码没有错误
我是一名优秀的程序员,十分优秀!