viv*_*vek 2 ruby excel zip xlsx rubyzip
我正在编写可以读取/写入 Excel xlsx 文件的代码。xlsx 文件只是几个 xml 文件的 zip 存档,因此为了测试我是否可以编写文件,我使用了一个名为 gem 的 gemrubyzip来解压缩 xlsx 文件,然后立即将其压缩回新存档,而不修改数据。然而,当我这样做时,我无法打开新的 Excel 文件,据说它已损坏。
或者,如果我使用 Mac OS X 的 Archive Utility(处理 zip 文件的本机应用程序),并且解压缩并重新压缩 Excel 文件,则数据不会损坏,并且我可以在 Excel 中打开生成的文件。
我发现rubyzip“损坏”数据的不是“解压缩”功能,而是压缩过程。(事实上,当我对rubyzip创建的新 zip 文件使用 Archive Utility 时,Excel 再次可以读取该文件)。
我想知道为什么会发生这种情况,以及有哪些解决方案可以以 Excel 可读的方式以编程方式压缩内容。
我的压缩代码:
def compress(path)
path.sub!(%r[/$],'')
archive = File.join(path,File.basename(path))+'.zip'
FileUtils.rm archive, :force=>true
Zip::ZipFile.open(archive, 'w') do |zipfile|
Dir["#{path}/**/**"].reject{|f|f==archive}.each do |file|
temp = file
zipfile.add(file.sub(path+'/',''),file)
end
end
end
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2296 次 |
| 最近记录: |