如何捕获文件的头,然后对原始文件执行进一步的文本处理



我想捕获以下文件的前 8 行,然后捕获 NPU # 等于 7 或 3 且 NPU 核心等于 1 的所有字段。

RP/0/RP0/CPU0:xxxxx#show controllers npu voq-usage interface all instance all location 0/0/CPU0
33144 Tue Jun  4 xxxx
33145 -------------------------------------------------------------------
33146 Node ID: 0/0/CPU0
33147 Intf         Intf     NPU NPU  PP   Sys   VOQ   Flow   VOQ    Port
33148 name         handle    #  core Port Port  base  base   port   speed
33149 (hex)                                     type
33150 ----------------------------------------------------------------------
33151 Hu0/0/2/1    210       0   1   21    21   1024   4152 local   100G
33152 Hu0/0/2/47   218       7   0    1   701   1032   4152 local   100G
33153 Hu0/0/2/46   220       7   0    5   705   1040   4216 local   100G
33154 Hu0/0/2/45   228       7   0    9   709   1048   4280 local   100G
33155 Hu0/0/2/44   230       3   1   17   717   1056   4152 local   100G

我能够使用以下不同的awk命令来做到这一点:

awk 'NR<9' filename.txt
awk '($4==7||$4==3) && $5==1' filename.txt

我可以得到一些关于如何将这些尴尬语句连接在一起的建议吗?或者甚至是一种更优雅的抨击主义来实现这一目标?

谢谢

我建议使用||运算符并对第二个条件进行分组:

awk 'NR<9 || (($4==7||$4==3) && $5==1)' filename.txt > newfilename.txt

查看在线演示:

s="RP/0/RP0/CPU0:xxxxx#show controllers npu voq-usage interface all instance all location 0/0/CPU0
33144 Tue Jun  4 xxxx
33145 -------------------------------------------------------------------
33146 Node ID: 0/0/CPU0
33147 Intf         Intf     NPU NPU  PP   Sys   VOQ   Flow   VOQ    Port
33148 name         handle    #  core Port Port  base  base   port   speed
33149 (hex)                                     type
33150 ----------------------------------------------------------------------
33151 Hu0/0/2/1    210       0   1   21    21   1024   4152 local   100G
33152 Hu0/0/2/47   218       7   0    1   701   1032   4152 local   100G
33153 Hu0/0/2/46   220       7   0    5   705   1040   4216 local   100G
33154 Hu0/0/2/45   228       7   0    9   709   1048   4280 local   100G
33155 Hu0/0/2/44   230       3   1   17   717   1056   4152 local   100G"
awk 'NR<9 || (($4==7||$4==3) && $5==1)'  <<< "$s"

输出:

RP/0/RP0/CPU0:xxxxx#show controllers npu voq-usage interface all instance all location 0/0/CPU0
33144 Tue Jun  4 xxxx
33145 -------------------------------------------------------------------
33146 Node ID: 0/0/CPU0
33147 Intf         Intf     NPU NPU  PP   Sys   VOQ   Flow   VOQ    Port
33148 name         handle    #  core Port Port  base  base   port   speed
33149 (hex)                                     type
33150 ----------------------------------------------------------------------
33155 Hu0/0/2/44   230       3   1   17   717   1056   4152 local   100G
awk '(NR<9) || (($4~/^[73]$/) && ($5==1))' filename.txt

你能再尝试 1 种方法吗?

awk 'NR<=9{print;next} ($4==7||$4==3) && $5==1'  Input_file

这可能对你有用(GNU sed(:

sed -E '1,8b;/^(S+s+){3}[37]s+1s/!d' file
打印第 1

行到 8 以及第 4 个字段为 3 或 7 且第 5 个字段为 1 的任何行。

最新更新