linux - what - awk print column $ 3 si $ 2== un valor específico?
awk linux command (6)
Estoy aprendiendo awk del lenguaje de programación awk y me molesta este ejemplo.
Si quiero imprimir $ 3 si $ 2 es igual a un valor (por ejemplo, ''1 ''), y estaba usando este comando que funciona bien:
awk ''$2==1 {print $3}'' <infile> | more
Pero cuando sustituyo 1 por otro criterio de búsqueda, por ejemplo ''findtext'' y este comando no funciona.
awk ''$1== findtext {print $3}'' <infile> | more
Esto no devuelve nada y estoy seguro de que lo que puse en ''Findtext'' existía en ese lugar. ¿Hay algún problema con mi sintaxis?
Intenté esto pero no funciona:
awk ''$1== "findtext" {print $3}'' <infile> | more
Pero cuando lo hago
grep findtext <infile> ## This does give me output
El findtext existe en el $ 1 como comprobé dos veces.
Aquí está mi archivo de prueba llamado ''prueba'', por ejemplo, tiene 9 líneas yy 8 campos y espacio separados:
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
Esto es lo que hice y el resultado:
$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
Espero ver esto, que es el $ 3 que tiene "ClNonZ" en sus $ 8.
0.180467091
0.010615711
0.492569002
No sé por qué el comando awk no devolvió nada. ¿Alguna idea?
Este método usa regexp, debería funcionar:
awk ''$2 ~ /findtext/ {print $3}'' <infile>
Esto es más legible para mí
awk ''{if ($2 ~ /findtext/) print $3}'' <infile>
Mi versión de awk es 3.1.5.
Sí, el archivo de entrada está separado por espacios, sin pestañas.
De acuerdo con la respuesta de Arutaku, esto es lo que intenté que funcionó:
awk ''$8 ~ "ClNonZ"{ print $3; }'' test
0.180467091
0.010615711
0.492569002
$ awk ''$8 ~ "ClNonZ" { print $3}'' test
0.180467091
0.010615711
0.492569002
Lo que no funcionó (no sé por qué y quizás debido a mi versión de awk :),
$awk ''$8 ~ "^ClNonZ$"{ print $3; }'' test
$awk ''$8 == "ClNonZ" { print $3 }'' test
¡Gracias a todos por sus respuestas, comentarios y ayuda!
Según la implementación de AWK
, ¿está utilizando ==
está bien o no?
¿Has probado ~
? Por ejemplo, si quiere que $ 1 sea "hola":
awk ''$1 ~ /^hello$/{ print $3; }'' <infile>
^
significa $ 1 inicio y $
es $ 1 final.
Si estás buscando una cadena en particular, pon comillas alrededor de ella:
awk ''$1 == "findtext" {print $3}''
De lo contrario, awk asumirá que es un nombre de variable.
por favor prueba esto
echo $VAR | grep ClNonZ | awk ''{print $3}'';
o
echo cat filename | grep ClNonZ | awk ''{print $3}'';