在AWK中添加行?

时间:2017-12-09 07:01:15

标签: gnu gawk

你能帮帮我吗?我需要帮助编码AWK,我无法解决这个问题。也可以是BASH解决方案。 代码:

1
4
7
5
5
1
4
8
3
6

我想要的输出是 代码:

1 5 .2
4 5 .8
7 12 .58
5 12 .41
5 6  .83
1 6  .16
4 12 .33
8 12 .66
3 9 .5
6 9  .5

如您所见,我需要将偶数行和奇数行一起添加以生成第二列。这个值保留为2行,因为我需要进行一些搜索并添加结果以获得百分比。

之后我需要将第一列中的值除以第二列中相同点的值。获得百分比。

我无法有效地完成任务。我现在正在做的只是将奇数行放在与偶数文件不同的文件中,然后附加列并继续为两个文件创建数组,然后进行代数。必须是使用AWK的简单方法,不涉及临时文件或类似的东西。

在以下文本文件中使用dudiboy建议的代码片段时,这些是我得到的错误结果:

这是list.txt文件内容:

1
2
6
6
8
1
2
3
5


root@debian:/home/l0l/Documents/awk# awk 'a[NR]=$1; END {for (ln=2; ln<=NR; ln+=2){ print(a[ln], a[ln]+a[ln-1], a[ln]/a[ln-1]); print(a[ln], a[ln]+a[ln-1], a[ln-1]/a[ln]);}}' list.txt
1
2
6
6
8
1
2
3
5
2 3 2
2 3 0.5
6 12 1
6 12 1
1 9 0.125
1 9 8
3 5 1.5
3 5 0.666667 

这个百分比已经过时了,打印它的方式也有所不同,我会继续尝试,但我真的很感激任何帮助。请逐步指导我建议的命令?

更新:     $ awk -v fmt =&#34;% - 2i%-2i%.2f \ n&#34; &#39; NR%2 {x = $ 1; next} {printf fmt,x,x + $ 1,x /(x + $ 1); printf fmt,$ 1,x + $ 1,$ 1 /(x + $ 1)}&#39;文件

PERFECT解决方案!!!!感谢十亿!很高兴!但是,当我尝试将命令输出到文件中时,我得到零分割错误

root@debian:/home/l0l/Documents/bash# awk -v fmt="%-2i %-2i %.2f\n" 'NR%2{x=$1;next} {printf fmt, x,x+$1,x/(x+$1); printf fmt,$1,x+$1,$1/(x+$1)}'     results >> RESULTS2.txt
awk: cmd. line:1: (FILENAME=results FNR=648) fatal: division by zero attempted

我在2000部分的数字列表中使用它,并且有时连续2个零。所以它产生第二列也是0,然后因为我们除以零,我们得到这个零分割问题。我们如何防止这种情况?我必须将0保留在文件中,这非常重要。也许以不同的方式计算百分比? 如何在没有零分割的情况下获得良好的输出? 例如,如果列表文件现在是:

0
0
1
5
5
6 
0
0
0
1
0
0

我们全面零分。有关如何防止这种情况的任何见解?

3 个答案:

答案 0 :(得分:1)

尝试:

$ awk -v fmt="%-2i %-2i %.2f\n" 'NR%2{x=$1;next} {printf fmt, x,x+$1,x/(x+$1); printf fmt,$1,x+$1,$1/(x+$1)}' file
1  5  0.20
4  5  0.80
7  12 0.58
5  12 0.42
5  6  0.83
1  6  0.17
4  12 0.33
8  12 0.67
3  9  0.33
6  9  0.67

更新的问题,避免除零

$ awk -v fmt="%-2i %-2i %.2f\n" 'NR%2{x=$1;next} {d=x+$1; printf fmt, x,d,(d?x/(x+$1):0); printf fmt,$1,d,(d?$1/(x+$1):0)}' file2
0  0  0.00
0  0  0.00
1  6  0.17
5  6  0.83
5  11 0.45
6  11 0.55
0  0  0.00
0  0  0.00
0  1  0.00
1  1  1.00
0  0  0.00
0  0  0.00

答案 1 :(得分:0)

这是一个简单的oneline awk示例;

awk 'a[NR]=$1; END {for (ln=2; ln<=NR; ln+=2){ print(a[ln], a[ln]+a[ln-1], a[ln]/a[ln-1]); print(a[ln], a[ln]+a[ln-1], a[ln-1]/a[ln]);}}' list.1.txt

希望这有帮助,任务不明确。

答案 2 :(得分:0)

表示所需的输出格式

$ awk 'BEGIN {fmt="%d %d %.2g\n"} 
       NR%2  {v=$1; next} 
             {s=v+$1; printf fmt fmt, v,s,v/s,$1,s,$1/s}' file

1 5 0.2
4 5 0.8
7 12 0.58
5 12 0.42
5 6 0.83
1 6 0.17
4 12 0.33
8 12 0.67
3 9 0.33
6 9 0.67