awk将匹配结果存入变量

1.match 函数将匹配存入到数组,下标从1开始,依次递增,注意awk是逐行处理的这个数组是单行匹配的一个数组。
2.awk工作流程是这样的:先执行BEGING,然后读取文件(也就是开始逐行处理了),读入有/n换行符分割的一条记录,然后将记录按指定的域分隔符划分域,填充域,$0则表示所有域,$1表示第一个域,$n表示第n个域,随后开始执行模式所对应的动作action。接着开始读入第二条记录······直到所有的记录都读完,最后执行END操作。
3.注意初始化内容放到begin后的第一个花括号中BEGIN {count=0;} {name[count] = $1;count++;};和
BEGIN {count=0;name[count] = $1;count++;};是有区别的,后者每次都会初始化count。而前者不会。
下面这个实例,用到了match,if 和数组:
awk   'BEGIN {count=0;}{match($0, /8\.([0-9]+) = INTEGER: ([0-9])+/, arr);if(arr[1]!=""){name[count]=arr[1];rxpower[count]=arr[2];count++};}; END{for (i = 0; i < count; i++) print name[i]}' 119.6.132.8_rxpower.txt 
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值