解決sublime text輸出decode error問題
sublime text有時執行會輸出以下錯誤資訊:
[Decode error - output not utf-8]或者[Decode error - output not gbk]
錯誤資訊意思就是指令碼輸出的資訊不是某種指定編碼.
指定的編碼一般在XX.sublime-build裡,比如ruby.sublime-build的內容為:
{
"shell_cmd": "ruby \"$file\"",
"file_regex": "(\\w:...*?):([0-9]*):?([0-9]*)",
"selector": "source.ruby",
"encoding" : "utf-8",
}
其中encoding就是指定的編碼,ruby.sublime-build可以在Sublime Text 3\Packages\Ruby.sublime-package裡找到.
(使用廣泛的Python.sublime-build在Python.sublime-package裡)
我們可以通過修改ruby.sublime-build來修改輸出文字資訊的編碼.
- 將ruby.sublime-build檔案從Ruby.sublime-package裡複製出來,(注意:Ruby.sublime-package是一個zip壓縮檔案,只要將其後綴名改為zip即可開啟這個壓縮檔案)
2.將ruby.sublime-build複製到sublime text的Data\Packages\User\目錄(可以先通過sublime的選單:Preferences->瀏覽程式包 開啟Data\Packages目錄)
- 開啟此檔案,將此檔案中的”encoding”: “utf-8″修改為”encoding”: “gbk”
以上這種修改有侷限,比如我有時候輸出的是utf-8,有時候輸出的是gbk,這時候就不行了.
以下方法可以解決這個侷限.
1.在sublime text的安裝目錄下的Packages\目錄下找到Default.sublime-package,將這個複製出來,將字尾改名為zip.
(注:我的檔案目錄:\Data\Packages\Default\exec.py)
是的,它就是個zip檔案,解壓縮它,然後將其中的exec.py檔案放到sublime text的Data\Packages\User\目錄下.
2.開啟exec.py.找到類ExecCommand的append_data函式,在以下位置新增程式碼
def append_data(self, proc, data):
if proc != self.proc:
# a second call to exec has been made before the first one
# finished, ignore it instead of intermingling the output.
if proc:
proc.kill()
return
try:
str = data.decode(self.encoding)
except:
#加下面一段try-except就行了,此處對原作者程式碼略微修改
try:
str = data.decode("gbk")
except:
str = "[Decode error - output not " + self.encoding + " and gbk]\n"
proc = None
# Normalize newlines, Sublime Text always uses a single \n separator
# in memory.
str = str.replace('\r\n', '\n').replace('\r', '\n')
self.output_view.run_command('append', {'characters': str, 'force': True, 'scroll_to_end': True})
其原理就是在解碼輸出文字編碼出錯時再使用gbk試試,相當於utf-8和gbk兩種編碼都試試,這樣可以解決編碼錯誤的問題.