AWK中的记录分隔符在最后一条记录后不适用?

时间:2016-01-08 19:50:05

标签: awk

我将ORS更改为,。我发现记录分隔符在最后一个输出记录之后应用。有没有办法让它不适用于最后一个输出记录?

同样。 OFS也适用于最后一个字段吗?如果是的话,我可以做到吗?

1 个答案:

答案 0 :(得分:6)

有几种技巧。

一个是,不使用内置ORS。

例如,而不是

$ seq 5 | awk -v ORS=",\n" '{print $0}'
1,
2,
3,
4,
5,

这样做

$ seq 5 | awk '{printf "%s%s",sep,$0; sep=",\n"} END{print ""}'
1,
2,
3,
4,
5

另一个技巧是从输入文件中删除最后一个新行并使用RT作为代理(可能只是gawk)

$ seq 5 | head -c -1 | awk -v ORS=",\n" '{printf "%s%s",$0,RT?ORS:""}'
1,
2,
3,
4,
5   # <-- no newline here but you can add in the END block.

对于OFS,你可以做类似的事情。

$ paste <(seq 5) <(seq 11 15) 
  | awk -v OFS=, '{sep=""; for(i=1;i<=NF;i++) {printf "%s",sep $i*$i; sep=OFS} printf "\n"}'

1,121
4,144
9,169
16,196
25,225

请注意,如果您没有在循环中构建该行,只需添加以逗号分隔的字段即可解决问题。例如print $1*$1, $2*$2