一:
有文本如下:
[01]123[04]
如何用awk将字符串用[]分隔开变成01 123 04
==============================================
方法1:
echo [01]123[04] | awk -F'[][]' '{print $2,$3,$4}'
方法2:
echo '[0]123[0]' | awk '{gsub(/[][]/," ",$0);print $1,$2,$3}'
方法3:
echo '[0]123[0]' | awk -F'[\\[\\]]' '{print $2,$3,$4}'
[[]]相当于普通字串[],-F '[[]]' 其实就是用"[]"为分隔符
[和]是就近匹配
echo [0[]123[0] | awk -F '[[]]' '{print $1,$2,$3}'
[0 123[0]
二:
file1 内容如下:
13113
313145
4151
5151515
file2内容如下:
13113
313145
526262
626262
4151
5151515
将两文件中相同的部分显示出来?
awk 'NR==FNR {a[$1]=$1} NR>FNR{$2=a[$1];print}' file1 file2 | awk '$1=$2 {print $1}'
解析:
NR,表示awk所读取的数据行数.
FNR,与NR功用类似,不同的是awk每打开一个新文件,FNR便从0重新累计
当只存在一个文件时NR始终等于FNR,当读取第二个文件时NR>FNR.
三:
现在有两个文件格式如下:
#cat account
张三|000001
李四|000002
#cat cdr
000001|10
000001|20
000002|30
000002|15
想要得到的结果是将用户名,帐号和金额在同一行打印出来,如下:
张三|000001|10
张三|000001|20
李四|000002|30
李四|000002|15
执行如下代码
#awk -F “|" 'NR==FNR{a[$2]=$0;next}{print a[$1]"|"$2}' account cdr
注释:
由NR=FNR为真时,判断当前读入的是第一个文件account,然后使用{a[$2]=$0;next}循环将account文件的每行记录都存入数组a,并使用$2第2个字段作为下标引用.
由NR=FNR为假时,判断当前读入了第二个文件cdr,然后跳过{a[$2]=$0;next},对第二个文件cdr的每一行都无条件执行{print a[$1]"|"$2},此时变量$1为第二个文件的第一个字段,与读入第一个文件时,采用第一个文件第二个字段$2为数组下标相同.因此可以在此使用a[$1]引用数组。
awk调用系统命令:(举例)
awk -F ":" '{print $0} END{system("date +%F")}' /etc/passwd
awk '{cmd="touch " $1;cmd|getline}' test.txt
awk 'sub(/www/,"abc")' /etc/passwd // passwd文件中把第一次出现的www替换为abc |
zcat www.example.com.cn.log | awk '{if($7 == "http://www.example.com/" && $9 == 200) print $1,$4,$7,$9,$10}'