分享awk变量$0的妙用
2013-03-02 19:34
661 查看
脚本内容:
#!/bin/bash
for ip in `cat ip.lst`
do
./ssh.exp $ip > /dev/null 2&>1
done
NK=`awk 'BEGIN{bs=4000000}/access/{if($1>bs){nk=NR-1;print nk}}' exp.log`
for nnk in $NK
do
awk -F"[@|']" 'NR=='"$nnk"' {print $2}' exp.log
done
然后又发现awk中$0的鬼怪。于是进一步简化成了这个样子:
复制代码 代码如下:#!/bin/bash
for ip in
`cat ip.lst`
do
./ssh.exp $ip > /dev/null 2&>1
done
awk 'BEGIN{bs=4000000}/access/{if($1>bs)print x};{x=$0}' exp.log|awk -F"[@|']" '{print $2}'
终于算是圆了自己用一句话搞定它的梦。yeah~ 不过对这个原理还是不很明白。因为print x;x=$0出来是上一行,但print $0则是本行。why? 网上对打印前一行还提出另一个写法,就看的更莫名其妙了:
awk '/regex/{print (x==""?"":x)};{x=$0}' $1
而打印后一行是这样:
awk '/regex/{getline;print}' $1
不过这毕竟是恰好上下行而已,如果是要前几行的,还是要靠NR运算了。
因为awk的流式处理,print x;x=$0,这个时候的x要等到下一行时才print出来。
相关文章推荐
- 分享awk变量$0的妙用
- awk 输出值到多个变量
- Linux中变量$#,$@,$0,$1,$2,$*,$$,$?的含义
- awk内置变量2-2
- linux中awk实例分享
- shell中字分隔的妙用:变量IFS
- 连载shell(二):test判断,判断符号[ ],shell script的默认变量($0, $1...),shift参数变量偏移
- awk中使用shell变量
- linux中shell变量的$#, $@,$0,$1,$2的含义
- Linux中变量$#,$@,$0,$1,$2,,$3,$4,$5,$6,$7,$8,$9,$*,$$,$?的含义
- awk中使用bash中定义的变量
- awk与shell之间的变量传递方法
- awk 调用变量
- awk中变量的作用域
- $0,$1,$2 and set - in shell ,awk ,sed,function ,perl
- 关于awk命令的几个内置变量(NF,NR,FS,FILENAME)
- Linux中变量$#,$@,$0,$1,$2,$*,$$,$?的含义
- awk使用shell中的变量
- awk ARGIND内置变量的使用以及comm命令的使用
- awk变量,批量更改有规则文件名