awk关联数组,模式为索引

时间:2013-06-03 01:28:38

标签: awk associative

将awk存储搜索模式以及在数组中找到的行的最佳解决方案是什么?我是否需要一个shell脚本或者只能使用awk来完成..

所以例如,如果我搜索单词'guitar',它会产生一个数组,其中包含例如在第13,18和89行找到该单词的信息?

awk '/home/ {
array[$0] = NR 
}
END {
for(i in array) print i, array[i] }' 1-1000.txt

例如,这将打印与找到它们的数字匹配的行..但我不需要$ 0但是'home'模式,作为关联数组的索引,它将行保存为值..但是然后又有问题如何为那个索引提供多个值?

1 个答案:

答案 0 :(得分:5)

重要的是要知道keys是唯一的。因此,如果您打算将搜索模式存储为键和行号作为值,则值将被模式的最后一行覆盖。

这样做的好方法是:

awk '{a[NR]=$1} END {for (k in a) if(a[k]=="monkey") print k}' textile

输出:

[jaypal:~] cat textfile
monkey
donkey
apple
monkey
dog
cat
mat
horse
monkey
[jaypal:~] awk '{a[NR]=$1} END {for (k in a) if(a[k]=="monkey") print k}' textfile
4
9
1

如果你需要遍历一行来寻找一个特定的模式并存储它,那么你可以使用for loop来检查该行的每个单词,一旦找到你的单词就将其存储为数组。

awk '{ for (i=1;i<=NF;i++) if($i=="pattern") arry[NR]=$i } END {. . .}' inputfile

根据评论进行更新:

迭代两个文件(其中一个用作查找,第二个用于搜索与查找匹配的行)。

awk 'NR==FNR{a[NR]=$1; next} {for (x in a) if ($0 ~ a[x]) print $0 " found because of --> " a[x]}' textile text2

测试:

[jaypal:~] cat text2
monkeydeal
nodeal
apple is a good fruit

[jaypal:~] awk 'NR==FNR{a[NR]=$1; next} { for (x in a) if ($0 ~ a[x]) print $0 " found on line number " FNR " because of --> " a[x]}' textfile text2
it is a good monkeydeal found on line number 1 because of --> monkey
it is a good monkeydeal found on line number 1 because of --> monkey
it is a good monkeydeal found on line number 1 because of --> monkey
apple is a good fruit found on line number 3 because of --> apple