【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表示在读取第一个文件。

posted @ 2018-07-12 14:57  匡子语  阅读(214)  评论(0编辑  收藏  举报