Подтвердить что ты не робот

Awk print column $3, если $2 == определенное значение?

Я изучаю awk из языка программирования awk и беспокоюсь об этом примере.

Если я хочу напечатать $3, если $2 равно значению (например, "1" ), и я использовал эту команду, которая отлично работает:

awk '$2==1 {print $3}' <infile> | more

Но когда я подставляю 1 другим критерием поиска, например "findtext", и эта команда не работает.

awk '$1== findtext {print $3}' <infile> | more

Это ничего не возвращает, и я уверен, что в этом месте я нашел "findtext". Что-то не так с моим синтаксисом?

Я пробовал это, но он не работает:

awk '$1== "findtext" {print $3}' <infile> | more

Но когда я делаю

grep findtext <infile>  ## This does give me output

Найденный текст существует в $1, когда я дважды проверял.

Здесь мой тестовый файл с именем "test", например, имеет 9 строк и 8 полей и пробелов:

1 11 0.959660297 0 0.021231423 -0.0073 -0.0031 MhZisp
2 14 0.180467091 0.800424628 0 0.0566 0.0103 ClNonZ
3 19 0.98089172 0 0 -0.0158 0.0124 MhNonZ
4 15 0.704883227 0.265392781 0.010615711 -0.0087 -0.0092 MhZisp
5 22 0.010615711 0.959660297 0.010615711 0.0476 0.0061 ClNonZ
6 23 0.715498938 0 0.265392781 -0.0013 -0.0309 Unkn
7 26 0.927813163 0 0.053078556 -0.0051 -0.0636 MhZisp
8 44 0.55626327 0.222929936 0.201698514 0.0053 -0.0438 MhZisp
9 31 0.492569002 0.350318471 0.138004246 0.0485 0.0088 ClNonZ

Вот что я сделал и вывод:

$awk '$8 == "ClNonZ" {print $3}' test 

$ grep ClNonZ test 
2 14 0.180467091 0.800424628 0 0.0566 0.0103 ClNonZ
5 22 0.010615711 0.959660297 0.010615711 0.0476 0.0061 ClNonZ
9 31 0.492569002 0.350318471 0.138004246 0.0485 0.0088 ClNonZ

Я ожидаю увидеть, что это $3, у которого есть "ClNonZ" в их $8.

0.180467091 
0.010615711 
0.492569002

Не знаю, почему команда awk ничего не вернула. любые мысли?

4b9b3361

Ответ 1

Если вы ищете определенную строку, поставьте туда кавычки:

awk '$1 == "findtext" {print $3}'

В противном случае awk примет это имя переменной.

Ответ 2

Этот метод использует regexp, он должен работать:

awk '$2 ~ /findtext/ {print $3}' <infile>

Ответ 3

В зависимости от реализации AWK вы используете == в порядке или нет.

Вы пробовали ~?. Например, если вы хотите, чтобы $1 был "привет":

awk '$1 ~ /^hello$/{ print $3; }' <infile>

^ означает начало $1, а $ - конец $1.

Ответ 4

Моя версия awk - 3.1.5.

Да, входной файл разделен пробелом, никаких вкладок.

В соответствии с ответом arutaku, вот что я пробовал, что сработало:

awk '$8 ~ "ClNonZ"{ print $3; }' test  
0.180467091
0.010615711
0.492569002


$ awk '$8 ~ "ClNonZ" { print $3}' test  
0.180467091
0.010615711
0.492569002

Что не работает (я не знаю, почему и возможно из-за моей awk-версии:),

$awk '$8 ~ "^ClNonZ$"{ print $3; }' test
$awk '$8 == "ClNonZ" { print $3 }' test

Спасибо всем за ваши ответы, комментарии и помощь!

Ответ 5

Это более читаемо для меня

awk '{if ($2 ~ /findtext/) print $3}' <infile>

Ответ 6

попробуйте это

echo $VAR | grep ClNonZ | awk '{print $3}';

или

echo cat filename | grep ClNonZ | awk '{print $3}';