亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

關于VIM編碼問題的解決

系統 1799 0

先放上自己前兩年做的幾個視頻吧,懶了,本打算做8個,只做了4個。

http://www.boobooke.com/v/bbk4407

http://www.boobooke.com/v/bbk4414

http://www.boobooke.com/v/bbk4415

http://www.boobooke.com/v/bbk4416

此文講解的是vim編輯多字節編碼文檔(中文)所要了解的一些基礎知識,注意其沒有涉及gvim,純指字符終端下的vim。
vim編碼方面的基礎知識:
1,存在3個變量:
encoding—-該選項使用于緩沖的文本(你正在編輯的文件),寄存器,Vim 腳本文件等等。你可以把 ‘encoding’ 選項當作是對 Vim 內部運行機制的設定。
fileencoding—-該選項是vim寫入文件時采用的編碼類型。
termencoding—-該選項代表輸出到客戶終端(Term)采用的編碼類型。
2,此3個變量的默認值:
encoding—-與系統當前locale相同,所以編輯文件的時候要考慮當前locale,否則要設置的東西就比較多了。
fileencoding—-vim打開文件時自動辨認其編碼,fileencoding就為辨認的值。為空則保存文件時采用encoding的編碼,如果沒有修改encoding,那值就是系統當前locale了。
termencoding—-默認空值,也就是輸出到終端不進行編碼轉換。
由此可見,編輯不同編碼文件需要注意的地方不僅僅是這3個變量,還有系統當前locale和、文件本身編碼以及自動編碼識別、客戶運行vim的終端所使用的編碼類型3個關鍵點,這3個關鍵點影響著3個變量的設定。
如果有人問:為什么我用vim打開中文文檔的時候出現亂碼?
答案是不確定的,原因上面已經講了,不搞清楚這3個關鍵點和這3個變量的設定值,出現亂碼是正常的,倒是不出現亂碼那反倒是湊巧的。
再來看一下常見情況下這三個關鍵點的值以及在這種情況下這3個變量的值:
1,locale—-目前大部分Linux系統已經將utf-8作為默認locale了,不過也有可能不是,例如有些系統使用中文locale
zh_CN.GB18030。在locale為utf-8的情況下,啟動vim后encoding將會設置為utf-8,這是兼容性最好的方式,因為內部
處理使用utf-8的話,無論外部存儲編碼為何都可以進行無缺損轉換。locale決定了vim內部處理數據的編碼,也就是encoding。
2,文件的編碼以及自動編碼識別—-這方面牽扯到各種編碼的規則,就不一一細講了。但需要明白的是,文件編碼類型并不是保存在文件內的,也就是說沒有任何
描述性的字段來記錄文檔是何種編碼類型的。因此我們在編輯文檔的時候,要么必須知道這文檔保存時是以什么編碼保存的,要么通過另外的一些手段來斷定編碼類
型,這另外的手段,就是通過某些編碼的碼表特征來斷定,例如每個字符占用的字節數,每個字符的ascii值是否都大于某個字段來斷定這個文件屬于何種編
碼。這種方式vim也使用了,這就是vim的自動編碼識別機制了。但這種機制由于編碼各式各樣,不可能每種編碼都有顯著的特征來辨別,所以是不可能
100%準確的。對于我們GB2312編碼,由于其中文是使用了2個acsii值高于127的字符組成漢字字符的,因此不可能把gb2312編碼的文件與
latin1編碼區分開來,因此自動識別編碼的機制對于gb2312是不成功的,它只會將文件辨識為latin1編碼。此問題同樣出現在gbk,big5
上等。因此我們在編輯此類文檔時,需要手工設定encoding和fileencoding。如果文檔編碼為utf-8時,一般vim都能自動識別正確的
編碼。
3,客戶運行vim的終端所使用的編碼類型—-同第二條一樣,這也是一個比較難以斷定的關鍵點。第二個關鍵點決定著從文件讀取內容和寫入內容到文件
時使用的編碼,而此關鍵點則決定vim輸出內容到終端時使用的編碼,如果此編碼類型和終端認為它收到的數據的編碼類型不同,則又會產生亂碼問題。在
linux本地X環境下,一般終端都認為其接收的數據的編碼類型和系統locale類型相符,因此不需關心此方面是否存在問題。但如果牽涉到遠程終端,例
如ssh登錄服務器,則問題就有可能出現了。例如從1臺locale為GB2310的系統(稱作客戶機)ssh到locale為utf-8的系統(稱作服
務器)并開啟vim編輯文檔,在不加任何改動的情況下,服務器返回的數據為utf-8的,但客戶機認為服務器返回的數據是gb2312的,按照
gb2312來解釋數據,則肯定就是亂碼了,這時就需要設置termencoding為gb2312來解決這個問題。此問題更多出現在我們的
windows
desktop機遠程ssh登錄服務器的情況下,這里牽扯到不同系統的編碼轉換問題。所以又與windows本身以及ssh客戶端有很大相關性。在
windows下存在兩種編碼類型的軟件,一種是本身就為unicode編碼方式編寫的軟件,一種是ansi軟件,也就是程序處理數據直接采用字節流,不
關心編碼。前一種程序可以在任何語言的windows上正確顯示多國語言,而后一種則編寫在何種語言的系統上則只能在何種語言的系統上顯示正確的文字。對
于這兩種類型的程序,我們需要區別對待。以ssh客戶端為例,我們使用的putty是unicode軟件,而secure CRT則是ansi
軟件。對于前者,我們要正確處理中文,只要保證vim輸出到終端的編碼為utf-8即可,就是termencoding=utf-8。但對于后者,一方面
我們要確認我們的windows系統默認代碼頁為cp936(中文windows默認值),另一方面要確認vim設置的termencoding=
cp936。
最后來看看處理中文文檔最典型的幾種情況和設置方式:
1,系統locale是utf-8(很多linux系統默認的locale形式),編輯的文檔是GB2312或GBK形式的(Windows記事本
默認保存形式,大部分編輯器也默認保存為這個形式,所以最常見),終端類型utf-8(也就是假定客戶端是putty類的unicode軟件)
則vim打開文檔后,encoding=utf-8(locale決定的),fileencoding=latin1(自動編碼判斷機制不準導致的),termencoding=空(默認無需轉換term編碼),顯示文件為亂碼。
解決方案1:首先要修正fileencoding為cp936或者euc-cn(二者一樣的,只不過叫法不同),注意修正的方法不是:set
fileencoding=cp936,這只是將文件保存為cp936,正確的方法是重新以cp936的編碼方式加載文件為:edit
++enc=cp936,可以簡寫為:e ++enc=cp936。
解決方案2:臨時改變vim運行的locale環境,方法是以LANG=zh_CN vim
abc.txt的方式來啟動vim,則此時encoding=euc-cn(locale決定的),fileencoding=空(此locale下文件
編碼自動判別功能不啟用,所以fileencoding為文件本身編碼方式不變,也就是euc-cn),termencoding=空(默認值,為空則等
于encoding)此時還是亂碼的,因為我們的ssh終端認為接受的數據為utf-8,但vim發送數據為euc-cn,所以還是不對。此時再用命令:
set termencoding=utf-8將終端數據輸出為utf-8,則顯示正常。
2,情況與1基本相同,只是使用的ssh軟件為secure CRT類ansi類軟件。
vim打開文檔后,encoding=utf-8(locale決定的),fileencoding=latin1(自動編碼判斷機制不準導致的),termencoding=空(默認無需轉換term編碼),顯示文件為亂碼。
解決方案1:首先要保證運行secure CRT的windows機器的默認代碼頁為CP936,這一點中文windows已經是默認設置了。其他的與上面方案1相同,只是要增加一步,:set termencoding=cp936
解決方案2:與上面方案2類似,不過最后一步修改termencoding省略即可,在此情況下需要的修改最少,只要以locale為zh_CN開
啟vim,則encoding=euc-cn,fileencoding和termencoding都為空即為encoding的值,是最理想的一種情
況。
可見理解這3個關鍵點和3個參數的意義,對于編碼問題有很大助力,以后就可以隨心所欲的處理文檔了,同時不僅僅是應用于vim,在其他需要編碼轉換的環境里,都可以應用類似的思路來處理問題解決問題。
最后推薦一款功能強大的windows下的ssh客戶端—-xshell,它具有類似secure CRT一樣的多tab
的ssh窗口的能力,但最為方便的是這款工具還有改變Term編碼的功能,這樣我們就可以不用頻繁調整termencoding,只需在ssh軟件里切換
編碼即可,這是我用過的最為方便的ssh工具。它是商業軟件,但非注冊用戶使用沒有任何限制,只是30天試用期超出后會每次啟動都提示注冊,對于功能沒有
絲毫影響。

關于VIM編碼問題的解決


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 爱爱的免费视频 | 成人在线播放 | 国产一级毛片在线 | 亚洲综合网在线观看首页 | 亚洲成人www| 国产粉嫩白浆在线观看 | 国产精品亚洲欧美一区麻豆 | 日日夜夜操美女 | 国产欧美精品综合一区 | 欧美性视频一区二区三区 | 日日操夜夜操免费视频 | 97视频| 久久er国产精品免费观看2 | 欧美中文字幕视频 | 男人深夜影院 | 亚洲精品视频网 | 不卡影院在线观看 | 天天插天天操天天干 | 国产精品线在线精品国语 | 一极毛片 | 国产成人亚洲精品老王 | 8x在线永久成人影院 | 青青青国产精品一区二区 | 中国一级特黄高清免费的大片 | 五月天婷婷久久 | 久久黄色小视频 | 久久亚洲美女久久久久 | 日本香蕉网 | 亚洲免费福利视频 | 奇米888四色在线精品 | 伊人色视频 | 日本免费一级 | 在线观看国产情趣免费视频 | 国产福利精品视频 | 久久综合九九亚洲一区 | 欧美日韩在线播放 | 国产精品久久一区二区三区 | 亚洲毛片视频 | 国产二区在线播放 | 国产亚洲精品国产福利在线观看 | 女性一级全黄生活片免费看 |