Linux下使用awk如何获取关键字所在字段号,第几列,以及打印这个字段之后的所有字段?

netstat 的原始结果如下:

[root@Test tmp]# netstat -tunp| grep 'ESTABLISHED'
tcp        0      0 10.251.101.163:6379         10.251.101.163:51602        ESTABLISHED 2115/redis-server 1
tcp        0      0 127.0.0.1:58657             127.0.0.1:3306              ESTABLISHED 13354/rpc_time_serv
tcp        0      0 10.251.101.163:52409        10.251.101.163:6379         ESTABLISHED 611/./SendMsgServer
tcp        0      0 127.0.0.1:54957             127.0.0.1:12000             ESTABLISHED 19186/php-fpm
tcp        0      0 10.251.101.163:6379         10.251.101.163:49821        ESTABLISHED 2115/redis-server 1
tcp        0      0 127.0.0.1:12000             127.0.0.1:45060             ESTABLISHED 1810/memcached

我想用awk处理输出结果为:

10.251.101.163:6379     ESTABLISHED    2115/redis-server 1
127.0.0.1:58657         ESTABLISHED    13354/rpc_time_serv
10.251.101.163:52409    ESTABLISHED    611/./SendMsgServer
127.0.0.1:54957         ESTABLISHED    19186/php-fpm
10.251.101.163:6379     ESTABLISHED    2115/redis-server 1
127.0.0.1:12000         ESTABLISHED    1810/memcached

以空格符为分隔符,因为每一行的字段数(列数)不一致,'ESTABLISHED'之后需要打印的字段数就不一样了。请问应该如何实现呢?
另外如果用固定字符位数的方式来输出应该是可以简单达到效果,但是为了泛用,不想以这种方式处理。
目前的想法是,获取'ESTABLISHED'所在的字段数,然后把该字段之后的字段打印,但是对awk不是很熟悉,不知道代码具体怎么写。
望高人指点...

阅读 9.3k
1 个回答
netstat -tunp| grep 'ESTABLISHED'| awk '{printf $4"    ";for(i=5;i<=NF;i++)if($i ~ /ESTABLISHED/)num=i;for(i=num;i<=NF;i++)printf $i"    ";printf"\n" }'

问了以前的同事,得到了在 awk 中 if 判断和 for 循环的简单写法,已经解决我的问题,前来自答。
其中涉及到的 awk 用法有:if 判断一个关键字所在列为第几列,用变量 num 保存字段号(列号);awk 中 for 循环的写法。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题