Quiero extraer algunas líneas con awk
. ¿Es posible hacer la siguiente tarea:
ls -l | awk 'BEGIN FOR(i=122;i<=129;i++) FNR==i'
¿Cómo puedo mostrar los detalles de los números de línea 122 a 129?
Quiero extraer algunas líneas con awk
. ¿Es posible hacer la siguiente tarea:
ls -l | awk 'BEGIN FOR(i=122;i<=129;i++) FNR==i'
¿Cómo puedo mostrar los detalles de los números de línea 122 a 129?
Respuestas:
No has entendido cómo awk
funciona. El "programa" especificado siempre se ejecuta una vez para cada línea (o "registro" en un lenguaje awk) de entrada, no hay necesidad de FOR
ninguna construcción similar. Solo usa:
método detallado
ls -l | awk 'NR>=122 && NR<=129 { print }'
método más compacto
ls -l | awk 'NR==122,NR==129'
Este da un rango para NR
, que es el "Registro de números", típicamente esta es la línea actual que se awk
está procesando.
awk
código típico para dicha tarea suele ser ls -l | awk 'NR==122,NR==129'
.
Un método alternativo más sería usar sed
:
ls -l | sed -ne '122,129p'
Pero si, como sugiere su pregunta, es importante usar awk para esto, vaya con el comentario de manatwork sobre la respuesta de Zrajm. Como dice la documentación de awk:
A pattern may consist of two patterns separated by a comma; in this case, the action is performed for all lines from an occurrence of the first pattern though an occurrence of the second.
Entonces, si lo desea, también puede hacer condiciones más avanzadas. Por ejemplo:
ls -l | awk 'NR==122,/foobar/'
Esto comenzaría la salida en la línea 122 y continuaría hasta que una línea contenga la palabra "foobar".
Si nos cuenta el caso de uso real , podríamos ayudarlo con respuestas que brinden una mejor solución. Me preocupa que esto parezca un problema XY .
sed
método, ya quesed
es mucho más pequeño (y se carga más rápido) queawk
.