0%

vim中的删除

Vim 删除操作

删除单个字符、词或者行

删除类似于拷贝,然而你必须使用d替代y。

描述
x 删除当前字符
dw 删除当前词
dj 删除当前行和下一行

这里应该可以出来以及技巧,x是删除,p是粘贴,
所以xp不是系统而是交互两个字符

VI下删除文本中的^M

关于回车与换行

很久以前,老式的电传打字机使用两个字符来另起新行。一个字符把滑动架移回首位 (称为回车,ASCII码为0D),另一个字符把纸上移一行 (称为换行, ASCII码为0A)。当计算机问世以后,存储器曾经非常昂贵。有些人就认定没必要用两个字符来表示行尾。UNIX 开发者决定他们可以用一个字符来表示行尾,linux沿袭Unix,也是。Apple 开发者规定了用.开发 MS-DOS以及Windows 的那些家伙则决定沿用老式的.

三种行尾格式如下:

  • unix : n
  • dos: rn
  • mac : r

这意味着,如果你试图把一个文件从一种系统移到另一种系统,那么你就有换行符方面的麻烦。

​ 因为MS-DOS及Windows是回车+换行来表示换行,因此在Linux下用Vim查看在Windows下写的代码,行尾后“^M”符号。

在Vim中解决这个问题,很简单,在Vim中利用替换功能就可以将“^M”都删掉,键入如下替换命令行:

1
:%s/^M//g

注意:

上述命令行中的“^M”符,不是“^”再加上“M”,而是由“Ctrl+v”、“Ctrl+M”键生成的,或者Ctrl+v,再按回车。

或者使用这个命令:

1
:% s/r//g

vim删除包含指定字符串的行

在命令模式中,使用如下指令删除包含指定字符串的行:

1
:g/string/d

delete Missing character: There is no ‏ (U+200F)

1
sed -i "s/$(echo -ne '\u200b')//g" file

或者在vim中如此操作:

1
%s/\%u200b//

vim删除重复行

使用vim内建的功能,如下即可快速在排序后删除重复的行:

1
:sort u

主要使用全局替换的操作

  • 删除空行
    :g/^$/d
  • 删除空行以及只有空格的行
    :g/^\s*$/d
  • 删除以 # 开头或 空格# 或 tab#开头的行
    :g/^\s*#/d
  • 删除以 ; 开头或 空格; 或 tab;开头的行
    :g/^\s*;/d

使用正则表达式删除行

  • 如果当前行包含 bbs ,则删除当前行
    :/bbs/d
  • 删除从第二行到包含 bbs 的区间行
    :2,/bbs/d
  • 删除从包含 bbs 的行到最后一行区间的行
    :/bbs/,$d
  • 删除所有包含 bbs 的行
    :g/bbs/d
  • 删除匹配 bbs 且前面只有一个字符的行
    :g/.bbs/d
  • 删除匹配 bbs 且以它开头的行
    :g/^bbs/d
  • 删除匹配 bbs 且以它结尾的行
    :g/bbs$/d
  • .ini 的注释是以 ; 开始的,如果注释不在行开头,那么删除 ; 及以后的字符
    :%s/\;.\+//g
  • 删除 # 之后所有字符
    %s/\#.*//g

Vim 删除所有行的指定字符到每行末尾的字符

:%s/ABCD.*$//g : 删除所有行的指定字符ABCD到每行末尾的字符

处无为之事,行不言之教;作而弗始,生而弗有,为而弗恃,功成不居!

欢迎关注我的其它发布渠道