Vorwort
In vielen Fällen ist das Komprimieren von Dateien unter Windows kein Problem, unter Linux erscheinen jedoch verstümmelte Zeichen, was sehr häufig vorkommt. Früher konnte man unter Ubuntu einfach `unzip -O GBK filename.zip`
verwenden. Nach dem Wechsel zu Fedora wurden noch keine verstümmelten komprimierten Dateien gefunden. Ich habe nachts eine CD mit einem Buch heruntergeladen und bin wieder auf verstümmelte Zeichen gestoßen. Versuchte die vorherige Methode ohne Erfolg. Ich habe mir die Hilfe von unzip angesehen und festgestellt, dass es keinen -O-Parameter gibt == Ich habe gerade eine Lösung mit Python gefunden, bitte teilen Sie sie.
Erstellen Sie eine neue Datei mit dem Suffix „.py“, kopieren Sie den Code und fügen Sie ihn direkt ein:
#!/usr/bin/env python # -*- coding: utf-8 -*- 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()
Führen Sie die Dekomprimierungs-ZIP-Datei aus Datei, süßes Chinesisch. Ist gerade erschienen.
python 文件名.py 需要解压的文件名.zip
Zusammenfassung
Okay, das war’s für diese Frage Es ist eine einfache Lösung. Hat sie jeder gelernt? Ich hoffe, dieser Artikel kann jedem beim Lernen oder bei der Arbeit helfen. Wenn Sie Fragen haben, können Sie eine Nachricht hinterlassen.
Weitere Python-Methoden zum Lösen verstümmelter chinesischer Zeichen beim Dekomprimieren von Zip durch Fedora finden Sie auf der chinesischen PHP-Website!