Products
GG网络技术分享 2025-03-18 16:13 0
正常来说,我们想要删除文件中的某些行内容,一般都是先打开这个文件,然后找到要删除的内容,再然后选中这些行并按删除键进行删除,这在数据量很少时是没有问题的。但是,一旦文件中的行数据非常多,而且数据冗杂的情况下,你还要用上面的方法去做的话就很恐怖了。为此,今天这篇文章将带大家一起学习运用 sed 命令行工具,即使在数据多而杂的情况下也能高效而优雅地删除文件中的特定行内容。
sed 是 Stream Editor 的简写,它用于在 Linux 中进行基本的文本转换,是文件操作的一个重要命令,所以,我们也可以用它来实现文本的删除操作。
下面是一些 sed 命令的使用示例,覆盖了大多数的使用场景,由浅入深地帮助你学习 sed 命令,让你轻松地实现高效删除文件的特定行内容。
首先我们准备一个演示文件 sed-demo.txt 。
# cat sed-demo.txt
1 Linux Operating System
2 Unix Operating System
3 RHEL
4 Red Hat
5 Fedora
6 Arch Linux
7 CentOS
8 Debian
9 Ubuntu
10 openSUSE
然后我们就可以运用 sed 命令进行实验了。
首先,我们先从删除某一行开始,比如删除第一行、最后一行,实际也就是第 N 行嘛。
删除第 N 行的命令格式:
sed 'Nd' file
我们来删除第一行试试:
# sed '1d' sed-demo.txt
After deletion:
2 Unix Operating System
3 RHEL
4 Red Hat
5 Fedora
6 Arch Linux
7 CentOS
8 Debian
9 Ubuntu
10 openSUSE
很简单是吧?这里就不多作解释了,你想要删除第几行的内容只需要把命令中的 1 替换一下就 ok 了。
那问题来了,最后一行用什么数字表示呢?这里给大家一个小提示,可以用美元符号 $ 表示最后,所以删除最后一行的命令可以这么写:
# sed '$d' sed-demo.txt
After deletion:
1 Linux Operating System
2 Unix Operating System
3 RHEL
4 Red Hat
5 Fedora
6 Arch Linux
7 CentOS
8 Debian
9 Ubuntu
sed 命令可以删除连续又或者不连续的行内容。
删除连续的行,例如删除从 5 到 7 行 的内容:
# sed '5,7d' sed-demo.txt
After deletion:
1 Linux Operating System
2 Unix Operating System
3 RHEL
4 Red Hat
8 Debian
9 Ubuntu
10 openSUSE
删除不连续的行,例如删除第 1 、第 5 、第 9 和最后一行:
# sed '1d;5d;9d;$d' sed-demo.txt
After deletion:
2 Unix Operating System
3 RHEL
4 Red Hat
6 Arch Linux
7 CentOS
8 Debian
另外,它还可以配合逻辑非 ! 使用,比如删除第 3到 6 行以外的其他行:
# sed '3,6!d' sed-demo.txt
After deletion:
3 RHEL
4 Red Hat
5 Fedora
6 Arch Linux
sed 还支持删除文件的空白行,命令如下:
# sed '/^$/d' sed-demo.txt
After deletion:
1 Linux Operating System
2 Unix Operating System
3 RHEL
4 Red Hat
5 Fedora
6 Arch Linux
7 CentOS
8 Debian
9 Ubuntu
10 openSUSE
假设我们想要删除示例文件中的包含 System 这个单词的行内容,我们可以用 /System/,它表示有出现 System 这个字符串就进行匹配,具体的命令如下:
# sed '/System/d' sed-demo.txt
After deletion:
3 RHEL
4 Red Hat
5 Fedora
6 Arch Linux
7 CentOS
8 Debian
9 Ubuntu
10 openSUSE
不仅如此,我们还可以加上一下逻辑条件,比方说下面的命令:
# sed '/System\\|Linux/d' sed-demo.txt
After deletion:
3 RHEL
4 Red Hat
5 Fedora
7 CentOS
8 Debian
9 Ubuntu
10 openSUSE
反斜杠 \\ 代表逻辑或,上述命令的意思是文本中有 System 或 Linux 的行都要进行删除。
首先,我们创建另一个示例文件 sed-demo-1.txt 进行更好地演示,其内容如下:
# cat sed-demo-1.txt
After deletion:
Linux Operating System
Unix Operating System
RHEL
Red Hat
Fedora
debian
ubuntu
Arch Linux - 1
2 - Manjaro
3 4 5 6
上面也已经提到过,$ 号可以理解为结尾,那么有没有字符可以代表开头呢?答案是有的,这里我们可以用 ^ 号代表开头。
那么,我们想要删除以某一个字符开头的行时,比如说删除以 R 开头的行,可以使用如下命令:
# sed '/^R/d' sed-demo-1.txt
After deletion:
Linux Operating System
Unix Operating System
Fedora
debian
ubuntu
Arch Linux - 1
2 - Manjaro
3 4 5 6
那么问题来了,比如我想删除以 R 或者 F 开头的行,那我是不是要执行两次命令呢?如果是有更多岂不是要执行多次命令?这里它有一个简单的写法,你只要把这些字符写在一对中括号 [] 里就可以了:
# sed '/^[RF]/d' sed-demo-1.txt
After deletion:
Linux Operating System
Unix Operating System
debian
ubuntu
Arch Linux - 1
2 - Manjaro
3 4 5 6
上面命令的作用是 删除以 R 或者 F 开头的行。
同上面一个道理,删除以某一个字符结尾的行,比方说删除以 m 结尾的行,我们可以这样做:
# sed '/m$/d' sed-demo.txt
After deletion:
3 RHEL
4 Red Hat
5 Fedora
6 Arch Linux
7 CentOS
8 Debian
9 Ubuntu
10 openSUSE
删除以 x 或 m 结尾的行可以这样写:
# sed '/[xm]$/d' sed-demo.txt
After deletion:
3 RHEL
4 Red Hat
5 Fedora
7 CentOS
8 Debian
9 Ubuntu
10 openSUSE
这里问题又来了,我想要删除所有以大写字母开头的行呢?按照上面的做法是不是要将 A 到 Z 这 26 个字母都写进 [ ] 里呢? 其实我们大可不必这样做,在 A 和 Z 中间加个 - 就可以了:
# sed '/^[A-Z]/d' sed-demo-1.txt
After deletion:
debian
ubuntu
2 - Manjaro
3 4 5 6
机智的你看到这里肯定会想到其他类似的用法的了,不妨看看下面是否有你想到的命令吧。
# sed '/[A-Za-z]/d' sed-demo-1.txt
After deletion:
3 4 5 6
# sed '/[0-9]/d' sed-demo-1.txt
After deletion:
Linux Operating System
Unix Operating System
RHEL
Red Hat
Fedora
debian
ubuntu
另外,通过这个例子,我们可以加上 ^ 和 $ 更好地看到他们三个之间的区别:
# sed '/^[0-9]/d' sed-demo-1.txt
After deletion:
Linux Operating System
Unix Operating System
RHEL
Red Hat
Fedora
debian
ubuntu
Arch Linux - 1
# sed '/[0-9]$/d' sed-demo-1.txt
After deletion:
Linux Operating System
Unix Operating System
RHEL
Red Hat
Fedora
debian
ubuntu
2 - Manjaro
实际上,我们要删除的文件内容是更为具体的,简单的条件是满足不了我们的需求的,所以,sed 也支持更复杂的条件组合。比方说我要指定删除在 1 到 6 行内有 Linux 这个词的内容,那么:
# sed '1,6{/Linux/d;}' sed-demo.txt
After deletion:
2 Unix Operating System
3 RHEL
4 Red Hat
5 Fedora
7 CentOS
8 Debian
9 Ubuntu
10 openSUSE
删除包含 System 以及其下一行的内容:
# sed '/System/{N;d;}' sed-demo.txt
After deletion:
3 RHEL
4 Red Hat
5 Fedora
6 Arch Linux
7 CentOS
8 Debian
9 Ubuntu
10 openSUSE> 2020 精选 阿里/腾讯等一线大厂 面试、简历、进阶、电子书 「**良许Linux**」后台回复「**资料**」免费获取
#### 看完的都是真爱,点个赞再走呗?您的「三连」就是良许持续创作的最大动力!
1. 关注**原创**「**良许Linux**」,第一时间获取最新Linux干货!
2. 后台回复【资料】【面试】【简历】获取精选一线大厂面试、自我提升、简历等资料。
3. 关注我的博客:[lxlinux.net](http://www.lxlinux.net)
大家平时工作中对不带空格的文件接触较多。这样一来删除操作也是比较简单的。但是有时我们会接触带有空格的文件。对于这种文件我们应该如何删除呢?
首先我们演示一下find命令结合xargs命令删除不带空格的文件
[root@ELK-chaofeng test]# touch 1.txt 2.txt [root@ELK-chaofeng test]# ls 1.txt 2.txt [root@ELK-chaofeng test]# find . -type f | xargs ./1.txt ./2.txt [root@ELK-chaofeng test]# find . -type f | xargs rm -rf [root@ELK-chaofeng test]# ls [root@ELK-chaofeng test]# |
接下来我们演示删除带有空格的文件
[root@ELK-chaofeng test]# touch 1.txt 2.txt \'1 2.txt\' [root@ELK-chaofeng test]# ls 1 2.txt 1.txt 2.txt [root@ELK-chaofeng test]# ll total 0 -rw-r--r-- 1 root root 0 Feb 14 12:24 1 2.txt -rw-r--r-- 1 root root 0 Feb 14 12:24 1.txt -rw-r--r-- 1 root root 0 Feb 14 12:24 2.txt [root@ELK-chaofeng test]# find . -type f -print0 | xargs -0 rm -rf [root@ELK-chaofeng test]# ls |
面的参数-print0,于默认的-print相比,输出的序列不是以空格分隔,而是以null字符分隔。而xargs也有一个参数-0,可以接受以null而非空格间隔的输入流。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持本网站!
Demand feedback