awk без печати новой строки - PullRequest
148 голосов
/ 07 января 2010

Я хочу, чтобы переменная сумма / 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

Ответы [ 6 ]

194 голосов
/ 07 января 2010

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

print вставит новую строку по умолчанию. Вы не хотите, чтобы это произошло, поэтому используйте вместо этого printf.

70 голосов
/ 07 января 2010

Переменная ORS (выходной разделитель записей) в AWK по умолчанию имеет значение "\ n" и печатается после каждой строки. Вы можете изменить его на "" в разделе BEGIN, если хотите, чтобы все печаталось последовательно.

36 голосов
/ 10 апреля 2015

Я полагаю, что многие люди задаются этим вопросом в поисках способа избежать новой строки в awk. Таким образом, я собираюсь предложить решение именно этого, поскольку ответ на конкретный контекст уже был решен!

В awk, print автоматически вставляет ORS после печати. ORS означает «разделитель выходной записи» и по умолчанию используется новая строка. Поэтому всякий раз, когда вы говорите, print "hi" awk печатает «привет» + новая строка.

Это можно изменить двумя различными способами: с помощью пустого 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" просто печатает «привет», ничего больше.

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

Наконец, обратите внимание, что в общем случае пропускается последняя новая строка, поэтому приглашение оболочки будет в той же строке, что и последняя строка вывода. Чтобы убрать это, используйте END {print ""}, чтобы после всей обработки была напечатана новая строка.

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

$ seq 5 | awk '{printf "%s", $0} END {print ""}'
12345
5 голосов
/ 07 января 2010

в одну сторону

awk '/^\*\*/{gsub("*","");printf "\n"$0" ";next}{printf $0" "}' to-plot.xls
1 голос
/ 27 октября 2016

Если Perl является опцией, вот решение на примере Федорки:

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

Пояснение:
chomp удаляет перевод строки
print "$_ " печатает каждую строку, добавляя пробел
блок END{} используется для печати новой строки

вывод: 1 2 3 4 5

0 голосов
/ 14 марта 2019

Вы можете просто использовать ORS динамически, как это:

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

...