码迷,mamicode.com
首页 > 系统相关 > 详细

vim 中文乱码怎么解决

时间:2018-08-01 22:19:56      阅读:172      评论:0      收藏:0      [点我收藏+]

标签:bsp   存在   lin   use   import   big   highlight   不同   rap   

一般来说只需要正确设置vim的编码识别序列就很少会遇到乱码问题:

set fileencodings=ucs-bom,utf-8,utf-16,gbk,big5,gb18030,latin1

这个设置是有顺序的,一般原则是尽可能把比较独特、不会和别的编码混淆的放在前面(例如ucs-bom,由于带有BOM头的关系很难和别的混淆),然后后面可以按照常用程度降序排列。latin1作为fallback放到最后。

 

这个序列可能还不是很科学也不是很完整(日文、韩文这两个也比较容易出错的就没有包括),但至少就我目前的使用情况来说(英文及一些ASCII扩展/变种、简体和繁体中文)都没有遇到过问题。如果有朋友知道更好的顺序,欢迎回复或者直接修改我的回答。

如果打开之后还是遇到了乱码,那么就需要手动指定编码了。注意,网络上很多地方提到的设置“fileencoding”(注意不带s)的方法是错误的。认真阅读帮助文档:
When reading a file ‘fileencoding‘ will be set from ‘fileencodings‘. To read a file in a certain encoding it won‘t work by setting ‘fileencoding‘, use the |++enc| argument.

当你打开一个文件以后,vim就已经选定好了编码并且认为就是这个编码了,set fileencoding只是修改你希望这个文件以什么编码存在,相当于是设置保存时的编码——一旦设置了不同的fileencoding之后这个文件就变成modified了,需要保存(编码变了)。

正确的做法是在打开文件时使用++enc参数:
:e ++enc=someencoding somefile

如果想重新打开当前文件的话就省略文件名somefile即可。这儿有一个wiki你可以看看:Reloading a file using a different encoding

最后,不要碰encoding这个设置!这是vim的内部编码,除非你确定知道你在干什么,否则一般不需要修改。

vim 中文乱码怎么解决

标签:bsp   存在   lin   use   import   big   highlight   不同   rap   

原文地址:https://www.cnblogs.com/zafu/p/9403714.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!