2

我有一个文件1:

6 
3 
6 
9 
2 
6

此命令打印结果:

awk 'NR==1{a=$1};$0!=a' file1
3 
9 
2

现在我有file2:

6 1 2 3 4 5 
3 3 4 4 4 6 
6 5 2 2 5 1 
9 1 3 5 4 1 
2 5 6 4 8 5 
6 1 5 2 3 1

我想做同样的事情,但使用 file2。我想打印出结果:

3 3 4 4 5 6 
9 5 3 2 8 1 
2 5 6 5 3 1 
    5 4   1 
      2

我想在awk中做到这一点。谢谢您的帮助。

4

1 回答 1

1

AWK 并不真正适合您尝试做的事情,因为它是为一次处理一行而设计的,而您正在尝试在不同行之间上下移动数字。也就是说,这个怪物应该做你想做的事:

awk 'NR==1{nc=NF;for(i=1;i<=nc;i++)a[i]=$i}{for(i=1;i<=nc;i++){if($i!=a[i]){v[m[i]++,i]=$i;if(m[i]>nl)nl=m[i]}}}END{for(l=0;l<nl;l++){for(i=1;i<=nc;i++){if(l<m[i]){printf("%d ", v[l,i])}else{printf("  ")}}printf("\n")}}'

另一方面,如果您的数字矩阵已被转置,则此任务会简单得多:

awk '{for(i=2;i<=NF;i++)if($i!=$1)printf(" %d",$i);printf("\n")}'
于 2012-11-11T11:44:00.843 回答