回答

收藏

Linux系统unzip解压后中文名乱码解决方法

Centos专区 Centos专区 931 人阅读 | 0 人回复 | 2021-09-05

中文名在linux中必须是乱码的哦这个没话说了,当然如果有配置好的估计是可以解决,下面小编整理了一些解决unzip解压后中文名乱码问题。
解决办法一,利用pyton来处理
1.vi uzip文件
2.复制以下内容
[Python] 纯文本查看 复制代码
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# uzip.py

import os
import sys
import zipfile

print "Processing File " + sys.argv[1]

file=zipfile.ZipFile(sys.argv[1],"r");
for name in file.namelist():
    utf8name=name.decode('gbk')
    print "Extracting " + utf8name
    pathname = os.path.dirname(utf8name)
    if not os.path.exists(pathname) and pathname!= "":
        os.makedirs(pathname)
    data = file.read(name)
    if not os.path.exists(utf8name):
        fo = open(utf8name, "w")
        fo.write(data)
        fo.close
file.close()

3.chmod +x uzip
4../uzip xxxx.zip

解决办法二 ,通过unzip行命令解压,指定字符集
[Bash shell] 纯文本查看 复制代码
unzip -O CP936 xxx.zip (用GBK, GB18030也可以)


有趣的是unzip的manual中并无这个选项的说明,unzip –help对这个参数有一行简单的说明。
解决办法三,在环境变量中,指定unzip参数,总是以指定的字符集显示和解压文件
/etc/environment中加入2行
UNZIP=”-O CP936″
ZIPINFO=”-O CP936″
4. 方法4,采用java的jar命令解压zip包 JAR 解压
[Actionscript3] 纯文本查看 复制代码
jar xvf file.name



分享到:
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

329 积分
40 主题