解決Python2.7讀寫文件中的中文亂碼問題
Python2.7對于中文編碼的問題處理的并不好,這幾天在爬數據的時候經常會遇到中文的編碼問題。但是本人對編碼原理不了解,也沒時間深究其中的原理。在此僅從應用的角度做一下總結,
1.設置默認編碼
在Python代碼中的任何地方出現中文,編譯時都會報錯,這時可以在代碼的首行添加相應說明,明確utf-8編碼格式,可以解決一般情況下的中文報錯。當然,編程中遇到具體問題還需具體分析啦。
#encoding:utf-8
或者
# -*- coding: utf-8 -*-
import sys
reload(sys)
sys.setdefaultencoding('utf8') # 設置默認編碼格式為'utf-8'
2.文件讀寫
文件讀寫中遇到中文,通常不會報錯,但是最后運行結果顯示亂碼,給后續(xù)處理帶來不便。
2.1 讀文件
讀文件時,如果文件路徑、文件名中有中文,需要使用unicode函數將其編碼為'utf-8'格式,然后再進行正常的文件讀取。以我常用的pandas的read_csv函數為例,使用如下代碼可以成功地讀取名為“POI總表”的csv文件,保存在DataFrame數據類型的poi_list。
import pandas as pd inpath = 'C:\\POI總表.csv' **path = unicode(inpath, 'utf-8')** poi_list = pd.read_csv(path)
2.2 寫文件
文件名有中文,文件名亂碼
當想要將程序運行結果保存到文本文件時,文本文件的命名中如果有中文,不做處理文件名會出現亂碼。利用unicode函數進行編碼可解。unicode(‘中文.csv','utf-8')
文件內容有中文,excel打開內容亂碼
如果將包含中文的結果輸出到csv文件,一般默認使用Excel打開文件時,文件內容會出現亂碼,而使用文本編輯器打開不會亂碼。這是因為Excel默認的編碼方式為‘GBK‘,而文本編輯器默認的格式為‘utf-8'。使用codecs包在創(chuàng)建文件后添加語句f.write(codecs.BOM_UTF8)可解
name='語文'
f = open(name+'.csv','w')
f.write('123,語文')
f.close()
#修改編碼
import codecs
f = open(**unicode(name+'.csv','utf-8')**,'w') # 文件名不亂碼
**f.write(codecs.BOM_UTF8) # excel打開內容不亂碼的核心語句**
f.write('123,語文')
f.close()
輸出結果:
#文件名:璇枃.csv #Excel打開 123 璇枃 #文本編輯器打開 123,語文 #改編碼后 #文件名:語文.csv #Excel打開 123 語文 #文本編輯器打開 123,語文
以上這篇解決Python2.7讀寫文件中的中文亂碼問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Python實現Linux系統(tǒng)上CI/CD工作流的方法詳解
在現代軟件開發(fā)中,持續(xù)集成(CI)和持續(xù)部署(CD)是提高開發(fā)效率、保證代碼質量的重要手段,下面我們來看看如何使用Python實現Linux系統(tǒng)的CI/CD工作流吧2025-04-04
Python統(tǒng)計一個字符串中每個字符出現了多少次的方法【字符串轉換為列表再統(tǒng)計】
這篇文章主要介紹了Python統(tǒng)計一個字符串中每個字符出現了多少次的方法,涉及Python字符串轉換及列表遍歷、統(tǒng)計等相關操作技巧,需要的朋友可以參考下2019-05-05
Pytorch backward報錯2次訪問計算圖需要retain_graph=True的情況詳解
這篇文章主要介紹了Pytorch backward報錯2次訪問計算圖需要retain_graph=True的情況,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-02-02

