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 awkfunciona. El "programa" especificado siempre se ejecuta una vez para cada línea (o "registro" en un lenguaje awk) de entrada, no hay necesidad de FORninguna 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 awkestá procesando.
awkcó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 .
sedmétodo, ya quesedes mucho más pequeño (y se carga más rápido) queawk.