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