合 Linux vi命令查看和修改文件字符集(乱码、dos2unix)
Tags: LinuxOS命令介绍乱码vim和vi命令删除多行文件格式字符集dos2unix
命令
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | -- vi查看文件字符集 :set fileencoding -- vi 查看文件格式,是unix还是dos :set fileformat -- vi以指定字符集打开 vi 文件名称 -c "e ++enc=GB2312" vi 文件名称 -c "e ++enc=GB18030" -- vi 转换文件字符集(需要先以正确的字符集打开) :set fileencoding=utf-8 -- 转换文件格式,从dos到unix(如何取消Linux下,vi中显示的^M符号) :set fileformat=unix dos2unix CC.txt |
示例
在linux环境下,有时候 vi 打开文件会遇到中文乱码问题,或者是原本可以正常执行的命令转移到另一台机器上就没法顺利执行了。
上面说的其实是两个问题,首先来说 vi 打开文件遇到中文乱码问题。
1 2 3 4 5 6 | vi 文件名称 打开文件一般这样展示 文件内容... ~ ~ "文件名称" [converted][dos] xxL, yyC |
可以看到最底下显示 “文件名称” [converted][dos] xxL, yyC
converted表示已经通过转换,这个转换是vi默认识别出的字符集,也是乱码的来源(请看后面解释)
dos表示是dos的格式,主要体现在回车换行上
xxL表示有xx行,L是行数lineNum的缩写
yyC表示有yy个字符,C表示字符格式,这里的数量和字符集有关系
如果要看当前文件的编码格式,请输入:set fileencoding
1 2 3 4 | 文件内容... ~ ~ :set fileencoding |
一般从windows中传入的文件,vi找不到对应的字符集,最后使用了fileencodding=latin1,导致乱码产生。
还可以指定 vi 查看文件的使用的编码格式,在 ~/.vimrc
文件中添加以下内容:set encoding=utf-8 fileencodings=utf-8
(这里是utf-8为例)。 这样就可以让vi自动识别文件编码,就是依照fileencodings提供的编码列表尝试,如果没找到适合的编码格式,就用latin1(ASCII)编码打开,这里解释了上面乱码的原因。