125 votes

utilisation de l'awk avec des conditions de valeur de colonne

J'apprends l'awk à partir de Le langage de programmation AWK et j'ai un problème avec l'un des exemples.

Si je voulais imprimer $3 si $2 est égal à une valeur (ex. 1 ), j'utilisais cette commande qui fonctionne bien :

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

Mais quand je remplace 1 par un autre critère de recherche, (par exemple findtext ), la commande ne fonctionne pas :

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

Il ne renvoie aucun résultat et je suis sûr que 'findtext' existe dans le fichier d'entrée.

J'ai également essayé ceci, mais cela ne fonctionne pas :

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

Voici mon fichier de test, nommé 'test', qui comporte 9 lignes et 8 champs, séparés par des espaces :

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 le résultat :

$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 leur 8 $.

0.180467091 
0.010615711 
0.492569002

Je ne sais pas pourquoi la commande awk n'a rien donné. Une idée ?

-3voto

Mustafa Points 58

Essayez ceci

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

ou

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

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X