我很难弄清楚如何循环一个简单的数组。我有this text file,基本上我的目标是选择以数字开头的所有行和a(英语相当于第1,第2,第3,第4等等),并为它们分配正确的分数。所以我写了这段代码:
#!/usr/bin/awk -f
BEGIN{FS="\t"}
/[0-9]+a/ {for (i=1; i<NR; i++) { score[i]=$3 } for (i=1; i<NR; i++) {print i, score[i]}}
这是我得到的疯狂输出:
1 25
1 20
2 20
1 16
2 16
3 16
1 13
2 13
3 13
4 13
1 11
2 11
3 11
4 11
5 11
1 10
2 10
3 10
4 10
5 10
6 10
1 9
2 9
3 9
4 9
5 9
6 9
7 9
1 8
2 8
3 8
4 8
5 8
6 8
7 8
8 8
1 7
2 7
3 7
4 7
5 7
6 7
7 7
8 7
9 7
1 6
2 6
3 6
4 6
5 6
6 6
7 6
8 6
9 6
10 6
1 5
2 5
3 5
4 5
5 5
6 5
7 5
8 5
9 5
10 5
11 5
1 4
2 4
3 4
4 4
5 4
6 4
7 4
8 4
9 4
10 4
11 4
12 4
1 3
2 3
3 3
4 3
5 3
6 3
7 3
8 3
9 3
10 3
11 3
12 3
13 3
1 2
2 2
3 2
4 2
5 2
6 2
7 2
8 2
9 2
10 2
11 2
12 2
13 2
14 2
1 1
2 1
3 1
4 1
5 1
6 1
7 1
8 1
9 1
10 1
11 1
12 1
13 1
14 1
15 1
我不明白它是如何可能的。你能帮我一下吗?
答案 0 :(得分:1)
虽然awk数组是相当散列的,但是用数据输入它们是没有问题的;你只需要:
/[0-9]+a/{scores[$1]=$2}
和scores['1a']=25
,scores['3a']=16
等
你可以使用for-in循环循环它:
/END/{for(e in scores) print(e,scores[e])}
答案 1 :(得分:0)
您不需要数组:
awk '/^[0-9]a/' YOURINPUT
1a 25
2a 20
3a 16
4a 13
5a 11
6a 10
7a 9
8a 8
9a 7