我一直在。vimrc中得到^M字符,它破坏了我的 配置。
这可能意味着您得到了回车(不同的操作系统使用不同的方式来表示行结束)。
使用dos2unix在vim中修复文件或设置文件格式:
set ffs=unix,dos
Unix使用0xA作为换行符。Windows使用两个字符的组合:0xD 0xA。0xD是回车符。^M恰好是vim显示0xD的方式(0x0D = 13, M是英语字母表中的第13个字母)。
您可以通过运行以下命令删除所有^M字符:
:%s/^M//g
其中^M是通过按住Ctrl并输入v + M,然后释放Ctrl来输入的。有时缩写为^V^M,但请注意,您必须按照上一句中描述的方式输入,而不是逐字输入。
这个表达式将把所有出现的^M替换为空字符串(即无)。我用这个来去掉从Windows复制到Unix (Solaris, Linux, OSX)的文件中的^M。
如果它破坏了您的配置,并且映射中需要^M字符,您可以简单地将^M字符替换为<Enter>或甚至<C-m>(两者都输入为简单字符序列,因此分别为7和5个字符)。
这是在映射中存储特殊键码的唯一推荐的可移植方法
我得到了一个文本文件最初是通过Mac用户在Windows机器上生成的,需要使用load data命令将它导入到Linux MySQL DB中。
尽管VIM显示了'^M'字符,但上述方法对我的特定问题都不起作用,数据会导入,但总是以某种方式损坏。在经历了很多挫折之后,最终解决方案非常简单。
解决方案: 在同一个文件上执行dos2unix两次就成功了!使用file命令可以显示整个过程中发生的事情。
$ file 'file.txt'
file.txt: ASCII text, with CRLF, CR line terminators
$ dos2unix 'file.txt'
dos2unix: converting file file.txt to UNIX format ...
$ file 'file.txt'
file.txt: ASCII text, with CRLF line terminators
$ dos2unix 'file.txt'
dos2unix: converting file file.txt to UNIX format ...
$ file 'file.txt'
file.txt: ASCII text
最终版本的文件被完美地导入数据库。
我用sed删除了它们:
Sed -i -e 's/\r//g' <filename>
也可以替换为不同的字符串或字符。例如,如果没有换行符,你可以把\r变成\n:
Sed -i -e 's/\r/\n/g' <filename>
这些sed命令适用于GNU/Linux版本的sed,但在bsd(包括macOS)上可能需要调整。
如果您没有故意指定不同的文件格式(例如,对于Windows文件,:e++ ff=unix),很可能目标文件的eol是混合的。
例如,如果一个文件有一些行以<CR><NL>结尾,而其他行以 <NL>结尾,文件格式被Vim读取时自动设置为unix, ^M (<CR>)将出现。 在这种情况下,文件格式(注意:有一个额外的s)发挥作用。详情见:help ffs。
推荐文章
- 如何生成一个核心转储在Linux上的分段错误?
- 在Python中如何在Linux和Windows中使用“/”(目录分隔符)?
- 使用sh shell比较字符串
- Visual Studio代码-在文件末尾插入换行符
- 使用vimdiff查看所有' git diff '
- 只列出UNIX中的目录
- 禁止在vim中创建交换文件
- NERDTree重载新文件
- 如何限制从grep返回的结果的数量?
- 如何管道列表的文件返回的找到命令到猫查看所有文件
- 以相对于当前目录的路径递归地在Linux CLI中列出文件
- 如何使用xargs复制名称中有空格和引号的文件?
- 在makefile中抑制命令调用的回声?
- 在Vim中,我想返回一个词。w的反义词
- Shell脚本for循环语法