本文摘自PHP中文网,作者零下一度,侵删。
由于zip格式中并没有指定编码格式,Windows下生成的zip文件中的编码是GBK/GB2312等,因此,导致这些zip文件在Linux下解压时出现乱码问题,因为Linux下的默认编码是UTF8。目前网上流传一种unzip -O cp936的方法,但一些unzip是没有-O这个选项的。
我使用的版本 unzip 6.0 debian modified 版本有这个选项
因为编码问题,zip文件中的中文文件在linux下解压会出现乱码
如果你使用archlinux那么使用AUR安装unzip-natspec就可以解决这个问题
这个时候,使用unzip xxx.zip就可以正确解压文件
然后在file-roller归档管理器中操作,中文名称依然是乱码,据说是因为file-roller优先使用p7zip
删除p7zip后问题解决
然而我还想同时能够使用p7zip软件包,谁知道这个问题如何解决?
从这里下载代码研究,发现这样的逻辑
1 2 3 4 5 6 7 8 |
|
这里是写死的,看起来除了给代码打补丁是没什么好办法了
最后的解决办法,发现AUR中同样存在类似的软件包p7zip-natspec
安装这个包应该就可以完美的解决问题吧,因为我已经使用上面的方法解决了问题,就不试这个了
以上就是linux下zip文件解压乱码该如何解决?的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
怎么使用instancemonitordatatype实例的监控数据集合
更多相关阅读请进入《Linux》频道 >>