創(chuàng)新互聯(lián)www.cdcxhl.cn八線動態(tài)BGP香港云服務(wù)器提供商,新人活動買多久送多久,劃算不套路!
專注于為中小企業(yè)提供成都做網(wǎng)站、網(wǎng)站制作服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)古冶免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上1000+企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。小編給大家分享一下如何解決python寫入文件亂碼的問題,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
對開發(fā)者來說,最惱人的問題之一莫過于讀寫文件的時候,由于編碼千差萬別,出現(xiàn)亂碼問題。好難快速解決啊。。。
下面說一下解決問題的思路
1. python中習慣首先聲明編碼類型
#!/usr/bin/python # -*- coding:-*- import sys reload(sys) sys.setdefaultencoding('utf-8')
PS:不一定所有文件都是 utf-8 編碼的,這里要注意。
2. 出現(xiàn)編碼問題時,首先查看下該文件的初始編碼方式,linux下命令為 :file -i filename,
eg:當前文件的編碼為 “ISO-8859-1”,隨后就將Python中的”utf-8“做了相應(yīng)修改。
在讀取文件時,需要先解碼:
str = str.decode("ISO-8859-1") ## 這樣返回的就是unicode的str
在寫入文件時,再用同樣的方式編碼(這里暫且不提文件轉(zhuǎn)碼):
str = str.encode("ISO-8859-1")
例如,解析一段“ISO-8859-1”編碼的json,代碼如下(更多學習內(nèi)容,請點擊python學習網(wǎng))
import json Jstr = json.loads(str, encoding="ISO-8859-1") ######## ## handle sth to ”data“ ######## print data.encode("ISO-8859-1")
這樣print 或 寫入的文件就不存在亂碼啦。
3:utf-8格式寫入文件
如果以上 json 文件是 utf-8 編碼,寫入后轉(zhuǎn)為了 unicode,現(xiàn)在要寫入utf-8,可以用如下方式:
import codecs name='xxx.json' f=codecs.open(name,'r',encoding='utf8') of=codecs.open(name+'.txt','w', encoding='utf8') for line in f: dictdata=json.loads(line) out=json.dumps(dictdata,indent=4, ensure_ascii=False) of.write(out+'\n') of.close()
以上是如何解決python寫入文件亂碼的問題的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道!