Awk不打印换行符

我希望变量sum/NR在每次迭代中并排打印。如何避免awk在每次迭代中打印换行符?在我的代码中,每次迭代默认打印换行符

for file in cg_c ep_c is_c tau xhpl
printf "\n $file" >> to-plot.xls
for f in 2.54 1.60 800
awk '{sum+=$3}; END  {print  sum/NR}' ${file}_${f}_v1.xls >> to-plot-p.xls
done
done

我希望输出是这样的

cg_c ans1  ans2  ans3
ep_c ans1  ans2  ans3
is_c ans1  ans2  ans3
tau  ans1  ans2  ans3
xhpl ans1  ans2  ans3

电流输出是这样的

**cg_c**
ans1
ans2
ans3
**ep_c**
ans1
ans2
ans3
**is_c**
ans1
ans2
ans3
**tau**
ans1
ans2
ans3
**xhpl**
ans1
ans2
ans3
222797 次浏览

AWK中的ORS(输出记录分隔符)变量默认为“\n”,并在每行之后打印。如果想要连续打印所有内容,可以在BEGIN部分中将其更改为" "。

awk '{sum+=$3}; END {printf "%f",sum/NR}' ${file}_${f}_v1.xls >> to-plot-p.xls

print默认会插入换行符。你不希望发生这种情况,因此使用printf代替。

的一种方法

awk '/^\*\*/{gsub("*","");printf "\n"$0" ";next}{printf $0" "}' to-plot.xls

我猜很多人在进入这个问题时都在寻找一种方法来避免awk中的新行。因此,我将提供一个解决方案,因为特定上下文的答案已经解决了!

awk中,print在打印后自动插入ORSORS代表“输出记录分隔符”,默认为新行。因此,每当你说print "hi" awk打印“hi”+新行。

这可以通过两种不同的方式改变:使用空ORS或使用printf

使用空ORS

awk -v ORS= '1' <<< "hello
man"

这将返回“helloman”。

这里的问题是,并不是所有的awks都接受设置一个空的ORS,所以你可能必须设置另一个记录分隔符。

awk -v ORS="-" '{print ...}' file

例如:

awk -v ORS="-" '1' <<< "hello
man"

返回“hello-man——”。

使用printf(更可取)

虽然print在记录之后附加了ORS,但printf没有。因此,printf "hello"只打印“hello”,没有其他内容。

$ awk 'BEGIN{print "hello"; print "bye"}'
hello
bye
$ awk 'BEGIN{printf "hello"; printf "bye"}'
hellobye

最后,请注意,这通常会遗漏最后一个新行,因此shell提示符将与输出的最后一行在同一行中。要清除这个,使用END {print ""},以便在所有处理之后打印新行。

$ seq 5 | awk '{printf "%s", $0}'
12345$
#    ^ prompt here


$ seq 5 | awk '{printf "%s", $0} END {print ""}'
12345

如果Perl是一个选项,下面是一个使用fedorqui的例子的解决方案:

seq 5 | perl -ne 'chomp; print "$_ "; END{print "\n"}'

< p >解释:< br > chomp删除换行
print "$_ "打印每行,附加一个空格
END{}块用于打印换行符

输出:1 2 3 4 5

你可以像这样简单地动态使用ORS:

awk '{ORS="" ; print($1" "$2" "$3" "$4" "$5" "); ORS="\n"; print($6-=2*$6)}' file_in > file_out

下面是不需要printfENDawk方法(假设你的输入小于,比如说,500 MB):

seq 199 |


mawk NF=NF RS='^$' FS='\n' OFS=
123456789101112131415161718192021222324252627282930313233343
536373839404142434445464748495051525354555657585960616263646
566676869707172737475767778798081828384858687888990919293949
596979899100101102103104105106107108109110111112113114115116
117118119120121122123124125126127128129130131132133134135136
137138139140141142143144145146147148149150151152153154155156
157158159160161162163164165166167168169170171172173174175176
177178179180181182183184185186187188189190191192193194195196
197198199

(为了可读性重新格式化-它是一行,结尾是\n)

如果你只是想在中间加个空格:

seq 19 |


mawk 'NF && --NF' RS='^$' FS='\n'
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19

如果您不介意多一个尾随空格,那么它就更简单了

mawk NF=NF RS='^$' FS='\n'