8

Как я могу использовать awk или sed для печати строки только до первого символа подчеркивания?

До:

host100_044 2
host101_045 2
host102_046 2

После:

host100
host101
host102

5 ответов5

17

Это можно сделать с помощью cut:

cut -d _ -f 1

например

$ echo host100_044 2 | cut -d _ -f 1
host100

Также с awk можно сделать с помощью awk -F_ '{print $1}' (возможно, есть более чистый способ сделать это)

2

Еще одна альтернатива для sed:

echo 'host100_044 2' | sed 's/^\(.*\)_.*$/\1/'

Если у вас есть это в файле, вы можете назвать это следующим образом;

cat fileName | sed 's/^\(.*\)_.*$/\1/'
1
echo host100_044 2 host101_045 2 host102_046 2| sed 's/_/ /g' | awk 'BEGIN { RS="host"} {printf("host%s ", $1)}'  | cut -d ' ' -f2-

Выход:

host100 host101 host102

С символами новой строки:

echo host100_044 2 host101_045 2 host102_046 2| sed 's/_/ /g' | awk 'BEGIN { RS="host"} $1 ~ /[0-9]/ {print "host"$1}'

Выход:

host100
host101
host102
1

Используя sed:

echo host100_044 2 | sed 's;_.*;;'


Используя sed в месте редактирования,

sed -i.old 's;_.*;;' infile
1
$ echo "host100_044 2" | awk -F'_' '{print $1}'
host100

-F'_' инструктирует awk использовать подчеркивания в качестве разделителей полей. Сам скрипт awk просто печатает первое поле.

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .