完美解決Python2操作中文名文件亂碼的問題
Python2默認是不支持中文的,一般我們在程序的開頭加上#-*-coding:utf-8-*-來解決這個問題,但是在我用open()方法打開文件時,中文名字卻顯示成了亂碼。
我先給大家說說Python中的編碼問題,Python中的字符串的大概分為為str和Unicode兩種形式,其中str常用的編碼類型為utf-8,gb2312,gbk等等,Python使用Unicode作為編碼的基礎(chǔ)類型。str記錄的是字節(jié)數(shù)組,只是某種編碼的存儲格式,終于輸出到文件或是打印出來是什么格式,完全取決于其解碼的編碼將他解碼成什么樣子;Unicode是一種類似于符號集的抽象編碼,它只規(guī)定了符號的二進制代碼,卻沒有規(guī)定這個二進制代碼該如何存儲,也就是它只是一種內(nèi)部表示,不能直接保存,所以存儲時需要規(guī)定一種存儲形式,比如utf-8等。
Python中有編碼轉(zhuǎn)換的函數(shù)有:
decode(char_set) 實現(xiàn)char_set解碼成Unicodeencode(char_set) 實現(xiàn)Unicode編碼成char_set

查看Python文檔會發(fā)現(xiàn):
open(filename, 'w')這個方法中,filename這個參數(shù)必須是Unicode編碼的參數(shù)。
我之前加上#-*-coding:utf-8-*-將編碼設(shè)置為utf-8,當調(diào)用這個方法往里傳參數(shù)時,需要將這個變量filename解碼成Unicode。
比如filename='中文.txt',使用open()時,這樣寫open(filename.decode('utf-8'), 'w'),這樣創(chuàng)建的中文文件名就沒有亂碼問題了。
以上就是小編為大家?guī)淼耐昝澜鉀QPython2操作中文名文件亂碼的問題全部內(nèi)容了,希望大家多多支持腳本之家~
相關(guān)文章
Django中自定義admin Xadmin的實現(xiàn)代碼
這篇文章主要介紹了Django中自定義admin---Xadmin的實現(xiàn)代碼,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下2019-08-08
?分享一個Python?遇到數(shù)據(jù)庫超好用的模塊
這篇文章主要介紹了?分享一個Python?遇到數(shù)據(jù)庫超好用的模塊,SQLALchemy這個模塊,該模塊是Python當中最有名的ORM框架,該框架是建立在數(shù)據(jù)庫API之上,使用關(guān)系對象映射進行數(shù)據(jù)庫的操作,,需要的朋友可以參考下2022-04-04
Python?PaddleGAN實現(xiàn)照片人物性別反轉(zhuǎn)
PaddleGAN中的styleganv2editing.py是支持性別編輯的。所以本文將介紹如何通過調(diào)整參數(shù),來試著實現(xiàn)一下照片的性別翻轉(zhuǎn)。感興趣的小伙伴可以學習一下2021-12-12
Keras中 ImageDataGenerator函數(shù)的參數(shù)用法
這篇文章主要介紹了Keras中 ImageDataGenerator函數(shù)的參數(shù)用法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07
scikit-learn處理缺失數(shù)據(jù)的方法與實踐
scikit-learn作為Python中廣泛使用的機器學習庫,提供了多種工具和技術(shù)來幫助我們處理缺失數(shù)據(jù),本文將詳細介紹sklearn處理缺失數(shù)據(jù)的方法,并提供實際的代碼示例,需要的朋友可以參考下2024-06-06

