在升級(jí)到EL Capitan后,SSH到遠(yuǎn)端的Server,運(yùn)行Python腳本處理數(shù)據(jù)。結(jié)果腳本報(bào)告出現(xiàn)異常:
UnicodeEncodeError: 'ascii' codec can't encode characters in position 18-21: ordinal not in range(128)
出現(xiàn)異常的地方是如下代碼:
print(app[‘name’], file=f) # 將app的名稱(可能含有中文)打印到文件中。
腳本沒有改動(dòng)過,怎么會(huì)出現(xiàn)UnicodeEncodeError呢?肯定是和系統(tǒng)升級(jí)有關(guān)。Google搜索時(shí)發(fā)現(xiàn)了下面這篇有用的Blog。
系統(tǒng)升級(jí)后locale設(shè)置有所變化:LANG和LC_CTYPE變?yōu)榱薳n_AU.UTF-8。當(dāng)ssh到server時(shí),會(huì)把locale信息傳給sshd,然后sshd根據(jù)locale信息來設(shè)置ssh session,由此會(huì)影響python的編解碼。sys.stdout.encoding自動(dòng)設(shè)置為'ANSI_X3.4-1968’。
SSH時(shí)使用“-vvv”選項(xiàng)打印出Debug信息后,發(fā)現(xiàn)果然會(huì)傳locale信息。
debug1: Sending env LC_CTYPE = en_AU.UTF-8
解決方法就是在bashrc或bash_profile中更新如下環(huán)境變量,使SSH客戶端和服務(wù)器端保持一致:
export LANG=en_US.UTF-8
export LC_CTYPE=en_US.UTF-8
export LC_ALL=en_US.UTF-8