Python出現(xiàn)的中文亂碼問題(SQL server妙同、PyQt砚蓬、Matplotlib)

一. 從SQL server讀取數(shù)據(jù)出現(xiàn)中文亂碼

【問題描述】: pymmsql連接SQL Server中文出現(xiàn)亂碼
中文亂碼

【問題分析】:①矢门、默認情況下SQL Server 使用ISO字符集(代碼頁1252)(latin1字符集)盆色;②灰蛙、python的 pymssql模塊默認以'utf8'編碼方式解碼(默認charset='utf8'); ③隔躲、數(shù)據(jù)庫內(nèi)的中文摩梧,被python以二進制的方式讀取后以'utf8'方式解碼顯示為亂碼,其二進制數(shù)據(jù)未改變宣旱。
【解決方案一】:將因'utf8'解碼成亂碼的str以其原正確的編碼方式'latin1'再次encode成正確的bytes然后以'GB2312'編碼方式解碼成正常的中文str: str.encode('latin1').decode('GB2312')

正常顯示

【解決方案二】:最近發(fā)現(xiàn)仅父,可以直接以GB18030讀取得到正常的中文,我的數(shù)據(jù)庫排序規(guī)則排序規(guī)則為“Chinese_PRC_CI_AS”
charset=GB18030

  • 至于為什么不用GB2312呢,因為包含的字符個數(shù):GB2312 < GBK < GB18030笙纤,如果用GB2312耗溜,在可能報錯:“UnicodeDecodeError: 'gb2312' codec can't decode byte 0xa9 in position 0: illegal multibyte sequence”

二. SQL Server 中文顯示為"???"

【問題描述】:SQL Server 2017中新建數(shù)據(jù)庫,用python寫入的中文數(shù)據(jù)顯示為"???"


中文顯示異常

【問題定位】:新建數(shù)據(jù)庫的排序規(guī)則默認為“SQL_Latin1_General_CP1_CI_AS”無法正常顯示中文
參看數(shù)據(jù)庫排序規(guī)則

【解決方案】:建庫的時候選擇排序規(guī)則“Chinese_PRC_CI_AS”后顯示正常省容,參考SQL SERVER建表時collate Chinese_PRC_CI_AS 是什么意思

選擇排序規(guī)則

三. PyQt的table中文bug

【問題描述】:Pyqt的table(widget)在未選中Item時直接輸入中文抖拴,UI界面卡死;
【問題定位】:經(jīng)排查發(fā)現(xiàn)腥椒,與table中使用了self.tableWidget.setCellwidget()有關阿宅;

【解決方案】:底層原因未明,暫時避免在使用了setCellwidget()的table中開啟編輯功能笼蛛。

四.Matplolib中出現(xiàn)中文亂碼

【問題描述】:matplotlib中文軸標簽成亂碼

軸標簽中文亂碼

【問題定位】:matplotlib從V2.0后默認字體僅包含西方字母的字形洒放, 沒有覆蓋中文、韓文或日文滨砍。參考Text properties and layout
【解決方案】:可添加代碼設置中文字體往湿,也可修改matplotlib配置文件,更改默認字體惨好,這里僅介紹前一種方法煌茴,第二種方法請參考:python matplotlib 中文顯示參數(shù)設置

import matplotlib as mpl
mpl.rcParams['font.sans-serif']=['KaiTi','SimHei']   #顯示漢字為 楷體, 漢字不支持 粗體日川,斜體等設置
mpl.rcParams['axes.unicode_minus']=False #用來正常顯示負號
mpl.rcParams['font.size'] = 10 

切記字體設置要在style之后蔓腐,否則可能依舊出現(xiàn)中文亂碼(在下被這個整整坑了一天半的時間),錯誤代碼如下

import matplotlib as mpl
mpl.rcParams['font.sans-serif']=['KaiTi','SimHei']   #顯示漢字為 楷體龄句, 漢字不支持 粗體回论,斜體等設置
mpl.rcParams['axes.unicode_minus']=False #用來正常顯示負號
mpl.rcParams['font.size'] = 10 
mpl.style.use('seaborn-whitegrid') # 可能導致字體設置失敗

五. windows英文系統(tǒng)顯示中文亂碼

【問題描述】:英文系統(tǒng)下,部分中文程序運行時出現(xiàn)中文亂碼
【問題定位】:中文程序所使用的文字編碼與Windows7英文系統(tǒng)的文字編碼不同分歇,所以會發(fā)生顯示亂碼的情況
【解決方案】:win7系統(tǒng)參考英文系統(tǒng)中文亂碼的解決

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末傀蓉,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子职抡,更是在濱河造成了極大的恐慌葬燎,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,348評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件缚甩,死亡現(xiàn)場離奇詭異谱净,居然都是意外死亡,警方通過查閱死者的電腦和手機擅威,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評論 2 385
  • 文/潘曉璐 我一進店門壕探,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人郊丛,你說我怎么就攤上這事李请∏粕福” “怎么了?”我有些...
    開封第一講書人閱讀 156,936評論 0 347
  • 文/不壞的土叔 我叫張陵导盅,是天一觀的道長较幌。 經(jīng)常有香客問我,道長白翻,這世上最難降的妖魔是什么绅络? 我笑而不...
    開封第一講書人閱讀 56,427評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮嘁字,結果婚禮上恩急,老公的妹妹穿的比我還像新娘。我一直安慰自己纪蜒,他們只是感情好衷恭,可當我...
    茶點故事閱讀 65,467評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著纯续,像睡著了一般随珠。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上猬错,一...
    開封第一講書人閱讀 49,785評論 1 290
  • 那天窗看,我揣著相機與錄音,去河邊找鬼倦炒。 笑死显沈,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的逢唤。 我是一名探鬼主播拉讯,決...
    沈念sama閱讀 38,931評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼鳖藕!你這毒婦竟也來了魔慷?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,696評論 0 266
  • 序言:老撾萬榮一對情侶失蹤著恩,失蹤者是張志新(化名)和其女友劉穎院尔,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體喉誊,經(jīng)...
    沈念sama閱讀 44,141評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡邀摆,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,483評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了裹驰。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片隧熙。...
    茶點故事閱讀 38,625評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡片挂,死狀恐怖幻林,靈堂內(nèi)的尸體忽然破棺而出贞盯,到底是詐尸還是另有隱情,我是刑警寧澤沪饺,帶...
    沈念sama閱讀 34,291評論 4 329
  • 正文 年R本政府宣布躏敢,位于F島的核電站,受9級特大地震影響整葡,放射性物質(zhì)發(fā)生泄漏件余。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,892評論 3 312
  • 文/蒙蒙 一遭居、第九天 我趴在偏房一處隱蔽的房頂上張望啼器。 院中可真熱鬧,春花似錦俱萍、人聲如沸端壳。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽损谦。三九已至,卻和暖如春岳颇,著一層夾襖步出監(jiān)牢的瞬間照捡,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工话侧, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留栗精,地道東北人。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓瞻鹏,卻偏偏與公主長得像术羔,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子乙漓,可洞房花燭夜當晚...
    茶點故事閱讀 43,492評論 2 348