2020-10-08 20:38:28 +01:00
|
|
|
# awk
|
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
> Un versátil lenguaje de programación para trabajar con archivos.
|
2020-10-08 20:38:28 +01:00
|
|
|
> Más información: <https://github.com/onetrueawk/awk>.
|
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
- Imprime la quinta columna (también conocida como campo) de un archivo separado por espacios:
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
`awk '{print $5}' {{ruta/al/archivo}}`
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
- Imprime la segunda columna de las líneas que contienen "foo" en un archivo separado por espacios:
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
`awk '/{{foo}}/ {print $2}' {{ruta/al/archivo}}`
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
- Imprime la última columna de cada línea de un archivo, utilizando una coma (en lugar de un espacio) como separador de campos:
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
`awk -F ',' '{print $NF}' {{ruta/al/archivo}}`
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
- Suma los valores de la primera columna de un fichero e imprime el total:
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
`awk '{s+=$1} END {print s}' {{ruta/al/archivo}}`
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
- Imprime una de cada tres líneas a partir de la primera:
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
`awk 'NR%3==1' {{ruta/al/archivo}}`
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
- Imprime diferentes valores basados en condiciones:
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
`awk '{if ($1 == "foo") print "Coincidencia exacta foo"; else if ($1 ~ "bar") print "Coincidencia parcial bar"; else print "Baz"}' {{ruta/al/archivo}}`
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
- Imprime todas las líneas en las que el valor de la 10ª columna sea igual al valor especificado:
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
`awk '($10 == valor)'`
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
- Imprime todas las líneas en las que el valor de la 10ª columna esté entre un mínimo y un máximo:
|
2020-10-08 20:38:28 +01:00
|
|
|
|
2023-12-28 08:44:47 +00:00
|
|
|
`awk '($10 >= valor_mín && $10 <= valor_máx)'`
|