我想捕获以下文件的前 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 的任何行。