当前位置:首页 » 操作系统 » linux多行删除

linux多行删除

发布时间: 2025-01-13 13:06:01

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`

热点内容
谷能压缩机 发布:2025-01-13 15:44:30 浏览:412
电脑电脑直连通讯ftp 发布:2025-01-13 15:38:03 浏览:717
nvm存储 发布:2025-01-13 15:36:19 浏览:552
京东架构师缓存经验 发布:2025-01-13 15:33:00 浏览:726
android图片颜色 发布:2025-01-13 15:26:09 浏览:268
国家税务总局电脑服务器 发布:2025-01-13 15:10:24 浏览:596
金立老款机的开机密码是多少 发布:2025-01-13 15:04:45 浏览:456
湖南网上办税初始密码多少 发布:2025-01-13 15:02:49 浏览:417
怎么使用笔记本连接服务器 发布:2025-01-13 15:02:48 浏览:705
长城cs75plus选哪个配置 发布:2025-01-13 14:54:05 浏览:22