Linux中,有时我们会分析较大的log文件,如果每个文件都手动进去查看的话效率会比较低,但每个文件的输出位置也不是固定的,可以结合sed
命令来过滤关键字,使得过滤出我们想要看到的内容。
下面我想使用sed
命令过滤出文件中,含有shyn
关键字那行以下,done
关键字那行以上的内容。
sed -n '/shyn/,$p' filename | sed '/done/q'
这条命令先使用 sed
查找并输出包含 “shyn” 关键字以下的内容,然后再使用另一个 sed
命令找到包含 “done” 关键字的行,并退出输出,这样就可以输出 “shyn” 关键字以下,“done” 关键字以上的内容。请将命令中的 “filename” 替换为你要操作的文件名。
详解
这条命令有两部分组成:
-
sed -n '/shyn/,$p' filename
:这部分命令使用sed
命令来读取文件 “filename”,从包含 “shyn” 关键字的那一行开始打印(包括这一行),直到文件的末尾。-n
选项表示关闭默认的打印功能,/shyn/,$
表示从包含 “shyn” 关键字的那一行开始打印直到文件结尾。 -
| sed '/done/q'
:这部分命令使用管道符号|
将第一部分的输出传递给第二部分的sed
命令。这个命令的作用是在第一部分的输出中查找 “done” 关键字,并在找到这个关键字时退出打印内容,即只打印 “done” 关键字之前的内容。
因此,整个命令的作用是输出文件中包含 “shyn” 关键字以下(包括这一行),但在遇到 “done” 关键字时停止输出。