web-dev-qa-db-fra.com

awk print column $ 3 si $ 2 == une valeur spécifique?

J'apprends awk avec le langage de programmation awk et je suis dérangé par cet exemple.

Si je veux imprimer $ 3 si $ 2 est égal à une valeur (par exemple, "1"), et que j'utilisais cette commande qui fonctionne correctement:

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

Mais lorsque je substitue 1 à un autre critère de recherche, par exemple "findtext" et cette commande ne fonctionne pas.

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

Cela ne renvoie rien en sortie et je suis sûr que ce que j'ai mis dans 'findtext' existait à cet endroit. Y a-t-il un problème avec ma syntaxe?

J'ai essayé ça mais ça ne marche pas:

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

Mais quand je fais

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

Le findtext est présent dans le $ 1 après vérification.

Voici mon fichier de test nommé 'test' par exemple, il a 9 lignes et 8 champs et espaces séparés:

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

Voici ce que j'ai fait et la sortie:

$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

Je m'attends à voir ceci qui est le 3 $ qui a "ClNonZ" dans leurs 8 $.

0.180467091 
0.010615711 
0.492569002

Je ne sais pas pourquoi la commande awk n'a rien retourné. Des pensées?

99
user1687130

Si vous recherchez une chaîne particulière, mettez des guillemets autour d'elle:

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

Sinon, awk supposera qu'il s'agit d'un nom de variable.

112
Rob Davis

Cette méthode utilise regexp, cela devrait fonctionner:

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

En fonction de l'implémentation AWK, utilisez-vous == est correct ou non.

Avez-vous essayé ~ ?. Par exemple, si vous voulez que $ 1 soit "bonjour":

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

^ signifie $ 1 début et $ est $ 1 fin.

17
arutaku

C'est plus lisible pour moi

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

Ma version de awk est 3.1.5.

Oui, le fichier d'entrée est séparé par des espaces, pas de tabulations.

Selon la réponse d'Arutaku, voici ce que j'ai essayé et qui a fonctionné:

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


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

Qu'est-ce qui n'a pas fonctionné (je ne sais pas pourquoi et peut-être à cause de ma version awk :),

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

Merci à tous pour vos réponses, commentaires et aide!

2
user1687130