【linux】awk相关
按字段相加文本内容
a 3
b 4
c 5
a 8
d 2
c 6
将上面内容中字段相同的数据相加
awk -F ' ' '{sum[$1]+=$2}END{for(i in sum){print i, sum[i]}}' test.txt
结果:
a 11
b 4
c 11
d 2
按字段拼接两个文本
文本1:
a 3
b 4
c 5
文本2:
a high
c middle
b low
根据第一个字段拼接两个文本
awk '{if(NR==FNR){x[$1]=$2}else{x[$1]=x[$1]" "$2}}END {for(i in x){print i, x[i]}}' test1.txt test2.txt
结果:
a 3 high
b 4 low
c 5 middle
注:
NR: 表示从所有文件中已读取的行数。
FNR:表示当前文件中已读取的行数。
举个栗子:
有两个文件,第一个文件有10行,第二个文件有15行。在读第一个文件的第5行时,NR=5,FNR=5。在读第二个文件的第8行的时候,NR=18,FNR=8。
所以NR==FNR表示在读取第一个文件。