awk 内嵌正则 提取字符串_使用awk提取JSON字符串中的字段

需求

从aaa.log文件中(文本为JSON串)中提取出phone字段对应的值。{"phone":"18633333333","code":"333333"}

{"phone":"18633333333","code":"000000"}

{"aaa":"888888","code":"888888","phone":"123456"}

{"phone":"18611111111","code":"111111"}

{"phone":"18655555555","code":"555555"}

{"aaa":"888888","phone":"7890123","code":"888888"}

substr字符串解决

适用于字段长度相同的情况awk -F '"phone":"' '{print substr($2,0,11)}' aaa.log

match正则匹配

正则:\"([^\"]*)\",匹配后取数组a第0个元素。awk -F '"phone":' 'match($2,/\"([^\"]*)\"/,a){print a[0]}' aaa.log

输出,带双引号:"18633333333"

"18633333333"

"123456"

"18611111111"

"18655555555"

"7890123"

match正则匹配方法二

正则:\"([^\"]*)\",匹配后取数组a第1个元素。awk -F '"phone":' 'match($2,/\"([^\"]*)\"/,a){print a[1]}' aaa.log

输出,不带双引号:18633333333

18633333333

123456

18611111111

18655555555

7890123

补充

执行match匹配时可能有警告信息如下,原因是awk版本5.0.0之后会有此提示信息,4.2.1版本无此警告信息。awk: cmd. line:1: warning: regexp escape sequence `\"' is not a known regexp operator

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值