将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'模式,作为关联数组的索引,它将行保存为值..但是然后又有问题如何为那个索引提供多个值?
答案 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