vim –cmd "set fileencoding=utf-8"

在很多时候,这个fileencoding无法发挥作用:

在windows上,用notepad将一个文本文件 test.txt 存储为unicode16或unicode16be

然后:vim –cmd “set fileencoding=utf-16” test.txt

它还是乱码,用 :set fileecoding 显示是 cp936

但是:vim –cmd “set fileencoding=utf-16”

不提供文件名,:set fileecoding 显示正确,是 utf-16

 

vim –help 提示:

   –cmd <command>      加载任何 vimrc 文件前执行 <command>

 

说明 fileencoding 是在某个 vimrc 中被修改了,这个“聪明的”vimrc 非常聪明地将fileencoding修改了

不过我好想没找到那个可以再执行完 vimrc 再执行命令的选项。

 

——————————————————————————

找到了一个办法,在 .vimrc 中,把fileencodings【注意,是复数】那行改成:

set fileencodings=utf-bom,UTF-8,UTF-16BE,UTF-16,g18030,big5,euc-jp,euc-kr,iso8859-1

因为utf,前四个,都是非常严格的编码,而 fileencodings 是需要把严格的编码放在最前的,因为它一旦尝试到一种成功的编码之后就不再继续尝试(没有做概率分析,看哪种编码最合适)。

有个插件,用概率分析判断编码:http://www.vim.org/scripts/script.php?script_id=1708

 

作者:
该日志由 rockeet 于2009年06月19日发表在杂谈分类下, 你可以发表评论,并在保留原文地址及作者的情况下引用到你的网站或博客。
转载请注明: vim –cmd "set fileencoding=utf-8"
标签:
【上一篇】
【下一篇】

您可能感兴趣的文章:

发表评论

您必须 登录 后才能发表评论。