linux多行删除
❶ linux怎么删除文件偶数行
删除偶数行的方法如下:
?
1
:g/^/+1 d
上面用到了:gbobal命令,gbobal命令格式如下:
?
1
:[range]global/{pattern}/{command}
global命令实际上是分成两步执行:首先扫描[range]指定范围内的所有行,给匹配{pattern}的行打上标记;然后依次对打有标记的行执行{command}命令,如果被标记的行在对之前匹配行的命令操作中被删除、移动或合并,则其标记自动消失,而不对该行执行{command}命令。{command}可以是一个ex命令,也可以是用|分隔的多个ex命令,这样我们就可以对被标记行,或从标记行寻址到的行进行多种不同的操作。
上面删除偶数行的命令,先匹配所有行,然后隔行删除(其中+1用以定位于当前行的下一行)。为什么是隔行呢?因为在对第一行执行+1 d命令时删除的是第二行,而第二行虽然也被标记了,但已不存在了,因此不会执行删除第三行的命令。
删除几数行的命令如下:
?
1
:g/^/d|m
其中m的作用是移出偶数行的标记,防止偶数行也被删除。
另外删除几数行偶数行,也可以用normal命令,分别为(第一个命令为几数行):
?
12
:%norm jkdd:%norm jdd
❷ linuxsed命令怎么通过正则删除多行
要通过Linux的sed命令删除多行,可以采用几种不同的方法。方法之一是使用`d`命令配合行号。例如,若需删除第5至第10行,命令如下:
`sed -i '5,10d' filename`
这里的`5,10`表示行号范围,`d`为删除命令,`filename`为文件名。
另一种方法是利用正则表达式删除匹配模式的多行。命令格式如下:
`sed -n '/pattern/p;N;D' filename`
这里的`/pattern`是正则表达式,`p`表示打印匹配行,`N`表示连接下一行,`D`用于删除连接后的行。举例,若要删除包含"hello"的行及其之后的两行:
`sed -n '/hello/p;N;D' filename`
使用sed命令打开文本文件并应用正则表达式匹配目标行。例如,以下命令会打开文件`test.txt`,并匹配以“start”开始、以“end”结尾的多行:
`sed -n '/start/,/end/p' test.txt`