首页 > 如何一句awk同时分割出IP和user-agent?

如何一句awk同时分割出IP和user-agent?

222.222.222.222 - - [10/May/2016:23:59:59 +0800] "GET /index.html HTTP/1.1" 200 2621 - "Mozilla/5.0 (iPhone; CPU iPhone OS 9_2_1 like Mac OS X; zh-CN) AppleWebKit/537.51.1 (KHTML, like Gecko) Mobile/13D15 UCBrowser/10.9.14.779 Mobile"

IP地址用了空格分割,可是user-agent却要用双引号,一条awk可否搞定?


awk加个-F [ " ] 选项,双引号前面有个空格,表示这两个都是分隔符


-F 指定多个分隔符在这个我觉得不是很好用,用下面这个方法我测试了可以实现,但是显得有点啰嗦

awk '{printf $1 " ";for(i=12;i<=NF;i++)printf $i " "; printf "\n"}' logfile


这个用grep或者sed会更直接,比如用grep:

grep -o '^[^ ]\+\|"[^"]\+"$' log | paste - -

用awk的话,如果是gawk 4.0,支持FPAT,那也比较直观:

awk 'BEGIN {FPAT="[^ ]+|\"[^\"]+\""} {print $1 " " $10}' log

不支持FPAT的话,那用gensub函数对$0执行类似sed的替换就是了。

【热门文章】
【热门文章】