awk ‘/字符串1/{a=1}a{b=b?b"\n"$0:$0;if(b~/字符串2/){print b;b=""}}’ file
sed -n ‘/字符串1/{p;:1;n;:2;/字符串2/{p;b1};N;b2}’ file
awk ‘/字符串1/{a=1}a{b=b?b"\n"$0:$0;if(b~/字符串2/){print b;b=""}}’ file
sed -n ‘/字符串1/{p;h;b};:m;x;/lzj/{x;N;/字符串2/!{bm;};p;b};x’ file
截取两个字符串之间日志
n 匹配行的下一行
N 追加到下一行
p 打印
P 打印到\n
b 无条件跳转 未匹配后面不执行
t 有条件跳转 未匹配执行后面
:fun1
在匹配B时,b func1 类似goto 跳转到 前面A匹配中
N 判断后拼接不匹配
n 判断后过滤不匹配
[root@docker tmp]# sed '/A/{p;:fun1 ; n ; :fun2 /B/{p;b fun1} ;n; b fun2} ’ file1 -n
AA
BC
CB
[root@docker tmp]#sed '/A/{p;:fun1 ; n ; :fun2 /B/{p;b fun1} ;N; b fun2} ’ file1 -n
AA
BC
AA
CB
[root@docker tmp]# cat file1
CC
AA
BC
AA
CB
CC
使用awk与sed截取日志
本文介绍如何利用awk和sed命令从日志文件中截取特定字符串之间的内容,详细解析了awk与sed的复杂用法,包括条件判断、行匹配、模式搜索等,适用于系统管理员和开发人员进行日志分析。
1112

被折叠的 条评论
为什么被折叠?



