2014-03-08 17:03:01 +00:00
# awk
2016-01-07 17:31:27 +00:00
> A versatile programming language for working on files.
2019-06-09 00:05:27 +01:00
> More information: <https://github.com/onetrueawk/awk>.
2014-03-08 17:03:01 +00:00
2016-07-16 13:30:28 +01:00
- Print the fifth column (a.k.a. field) in a space-separated file:
2014-03-08 17:03:01 +00:00
2022-12-06 06:47:56 +00:00
`awk '{print $5}' {{path/to/file}}`
2014-03-08 17:03:01 +00:00
2021-01-31 17:05:18 +00:00
- Print the second column of the lines containing "foo" in a space-separated file:
2016-02-04 18:30:40 +00:00
2022-12-06 06:47:56 +00:00
`awk '/{{foo}}/ {print $2}' {{path/to/file}}`
2016-02-04 18:30:40 +00:00
2016-07-16 13:30:28 +01:00
- Print the last column of each line in a file, using a comma (instead of space) as a field separator:
2014-03-08 17:03:01 +00:00
2022-12-06 06:47:56 +00:00
`awk -F ',' '{print $NF}' {{path/to/file}}`
2014-03-08 17:03:01 +00:00
2016-07-16 13:30:28 +01:00
- Sum the values in the first column of a file and print the total:
2014-03-08 17:03:01 +00:00
2022-12-06 06:47:56 +00:00
`awk '{s+=$1} END {print s}' {{path/to/file}}`
2014-03-08 17:03:01 +00:00
2018-02-23 06:05:11 +00:00
- Print every third line starting from the first line:
2022-12-06 06:47:56 +00:00
`awk 'NR%3==1' {{path/to/file}}`
2019-10-03 08:32:03 +01:00
- Print different values based on conditions:
2022-12-06 06:47:56 +00:00
`awk '{if ($1 == "foo") print "Exact match foo"; else if ($1 ~ "bar") print "Partial match bar"; else print "Baz"}' {{path/to/file}}`
2020-11-01 14:42:00 +00:00
2022-03-27 06:25:15 +01:00
- Print all the lines which the 10th column value is between a min and a max:
2020-11-01 14:42:00 +00:00
2024-01-01 18:53:36 +00:00
`awk '($10 >= {{min_value}} && $10 <= {{max_value}})'`
2024-08-25 15:17:39 +01:00
- Print table of users with UID >=1000 with header and formatted output, using colon as separator (`%-20s` mean: 20 left-align string characters, `%6s` means: 6 right-align string characters):
`awk 'BEGIN {FS=":";printf "%-20s %6s %25s\n", "Name", "UID", "Shell"} $4 >= 1000 {printf "%-20s %6d %25s\n", $1, $4, $7}' /etc/passwd`