Linux vi命令查看和修改文件字符集(乱码、dos2unix)
Tags: dos2unixLinuxOSvim和vi命令乱码删除多行命令介绍字符集文件格式
命令
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)编码打开,这里解释了上面乱码的原因。
解决步骤:
先指定字符集的方式打开文件,一般来说指定GB2312或者GB18030。看下是否出现乱码,如果没有中文乱码,那么恭喜。
1 2 | vi 文件名称 -c "e ++enc=GB2312" vi 文件名称 -c "e ++enc=GB18030" |
然后将文件保存为utf-8(一般都是utf-8编码),如果要转换编码并且保存,记得使用 :wq!
命令。
1 2 3 4 | 文件内容... ~ ~ :set fileencoding=utf-8 |
再来说一下原本可以正常执行的命令转移到另一台机器上就没法顺利执行的问题。
从windows上编辑脚本之后传到linux服务器可能会出现的,主要是回车换行的问题。
异常提示表现为:
1 2 3 | 文件名称: line xx: $'\r': command not found 文件名称: line xx: $'\r': command not found 文件名称: line xx: $'\r': command not found |
请使用 vi 文件名称 打开文件,然后执行 :set fileformat
命令
1 2 3 4 | 文件内容... ~ ~ :set fileformat |
如果显示为 fileformat=dos 那应该就是找到问题了关键了。
解决方式:
使用 vi 文件名称 打开文件之后,使用命令 :set fileformat=unix
可以解决,最后记得 :w 保存
1 2 3 4 | 文件内容... ~ ~ :set fileformat=unix |
另外,也可以使用
dos2unix 文件名
来转换。
123 [root@lhr soft]# dos2unix CC.txtdos2unix: converting file CC.txt to Unix format ...[root@lhr soft]#
参考
https://blog.csdn.net/xiaobin953326/article/details/122823828