我在Vagrant虚拟盒中的基本Ubuntu lucid32映像上运行带有Ruby 1.9.3p194的Rails(3.2.3)应用程序。虚拟盒正在Leopard上运行,因为它的价值。我正在尝试在应用程序中使用rubyzip解压缩zip存档 - 2009_da_lmp.zip
。直接使用rubyzip存储库中的示例代码,我可以确认我可以列出存档文件内容:
#f is the absolute path to 2009_da_lmp.zip (string)
Zip::ZipFile.open(f) { |zf| zf.entries[0] }
=> 20090101_da_lmp.csv #that is indeed a file in the archive.
使用存储库中示例中的更多代码,我尝试获取存档中的实际文件:
Zip::ZipInputStream.open(f) { |zis|
entry = zis.get_next_entry
print "first line of '#{entry.name}' (#{entry.size} bytes: ) "
puts "'#{zis.gets.chomp}'" }
=> first line of '20090101_da_lmp.csv' (826610 bytes: ) Zlib::DataError:
invalid stored block lengths #and a long stack trace I can provide
#if that might help
Mac OS解压缩实用程序将存档解压缩。我想知道它是否是某种编码相关的东西(我的语言环境设置为en_US.UTF-8,因为在开发中使用PostgreSQL不那么痛苦),但我不知道如何判断是否是这种情况。我找不到任何可能导致此错误的信息。
答案 0 :(得分:7)
这是将随机数据提供给inflater时发现的典型错误。实际上,您将从随机数据中获得此错误大约1/4的时间(当第一个字节的低三位为000或001时)。所以我猜想,由于某种原因,通货膨胀只是从错误的字节开始。