在命令输出中处理空列时获取第六列



试图从第一个col值匹配字符串的行的输出中获取第六列值。该代码因空间而断开。

尝试将结果输送到尴尬,但是如何处理空间?

command | awk '$1=="string_to_match" {print $6}

NAME                        ZONE        MACHINE_TYPE   PREEMPTIBLE  INTERNAL_IP  EXTERNAL_IP  STATUS
tensorflow-123456-111111    asu-bsu-b   n1-standard-4               00.111.0.1   00.11.2.345  RUNNING
tensorflow-123456-222222    asu-bsu-b   n1-standard-4  True         00.111.0.2   11.11.3.345  RUNNING

我希望通过匹配名称获得外部IP。

command | awk '$1=="tensorflow-123456-111111" {print $6}
RUNNING
// Want 00.11.2.345
command | awk '$1=="tensorflow-123456-222222" {print $6}
11.11.3.345

每个字段值是一个可变长度字符串。

对于您的特定情况,给定您更新的问题不是必需的使用gnu awk的标题进行宽宽:

$ cat tst.awk
NR==1 {
    nf = split($0,flds,FS,seps)
    for (i=1; i<=nf; i++) {
        FIELDWIDTHS = (i>1 ? FIELDWIDTHS " " : "") length(flds[i]seps[i])
    }
}
{
    for (i=1; i<=NF; i++) {
        val = $i
        sub(/s+$/,"",val)
        print NR, i, "<" val ">"
    }
    print "---"
}

$ awk -f tst.awk file
1 1 <NAME>
1 2 <ZONE>
1 3 <MACHINE_TYPE>
1 4 <PREEMPTIBLE>
1 5 <INTERNAL_IP>
1 6 <EXTERNAL_IP>
1 7 <STATUS>
---
2 1 <tensorflow-123456-111111>
2 2 <asu-bsu-b>
2 3 <n1-standard-4>
2 4 <>
2 5 <00.111.0.1>
2 6 <00.11.2.345>
2 7 <RUNNIN>
---
3 1 <tensorflow-123456-222222>
3 2 <asu-bsu-b>
3 3 <n1-standard-4>
3 4 <True>
3 5 <00.111.0.2>
3 6 <11.11.3.345>
3 7 <RUNNIN>
---

如果它可以帮助任何人,我最终基于@ps所做的一切。建议

command |awk '$1=="tensorflow-123456-111111 " {print $(NF-1)}'