Windows 終端問題
Windows 下的 cmd 和 powershell 默認(rèn)是 GBK 編碼顯示輸出內(nèi)容,這導(dǎo)致使用 UTF-8 的 Python 程序中的中文內(nèi)容(包括注釋、文檔、和字符串字面量)會以不正確的解碼方式輸出成亂碼內(nèi)容。
解決亂碼
Windows 內(nèi)置了一個叫 "chcp" 的命令,它可以修改要顯示的字符集編碼的編號。UTF-8 的編號是 65001,所以啟動 cmd 或者 powershell 以后可以手動輸入:
chcp 65001
來改變編碼。但是注意:僅靠修改代碼頁編號在 cmd 下仍然無法正常顯示中文,需要進(jìn)一步修改字體(有待考證)。我沒有這閑情,所以沒有管 cmd 了,因為在 powershell 下是正常的。
以前的 VSCode 是用 cmd 作為默認(rèn)終端的(所以還需要手動改默認(rèn)終端),現(xiàn)在發(fā)現(xiàn)不知道從什么版本開始,powershell 已經(jīng)變成默認(rèn)的終端了,不用再手動修改了。
修改終端程序是 JSON 配置中的 "terminal.integrated.shell.windows",而給終端程序啟動時加上參數(shù)的是:"terminal.integrated.shellArgs.windows" 。
所以在啟動 powershell 的時候帶上修改編碼的參數(shù): “chcp.com 65001” 即可做到自動設(shè)置編碼。
"terminal.integrated.shellArgs.windows": ["-NoExit", "/c", "chcp 65001"]
這樣也就算解決了亂碼問題了... 不過不得不說太惡心人了,幸好我基本上不用 Windows 寫代碼。