2014-03-08 12:03:01 -05:00
|
|
|
# awk
|
|
|
|
|
2016-01-07 18:31:27 +01: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 12:03:01 -05: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 12:03:01 -05:00
|
|
|
|
|
|
|
`awk '{print $5}' {{filename}}`
|
|
|
|
|
2021-01-31 14:05:18 -03:00
|
|
|
- Print the second column of the lines containing "foo" in a space-separated file:
|
2016-02-04 19:30:40 +01:00
|
|
|
|
2021-01-31 14:05:18 -03:00
|
|
|
`awk '/{{foo}}/ {print $2}' {{filename}}`
|
2016-02-04 19:30:40 +01: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 12:03:01 -05:00
|
|
|
|
2016-07-16 13:30:28 +01:00
|
|
|
`awk -F ',' '{print $NF}' {{filename}}`
|
2014-03-08 12:03:01 -05: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 12:03:01 -05:00
|
|
|
|
|
|
|
`awk '{s+=$1} END {print s}' {{filename}}`
|
|
|
|
|
2018-02-22 22:05:11 -08:00
|
|
|
- Print every third line starting from the first line:
|
|
|
|
|
|
|
|
`awk 'NR%3==1' {{filename}}`
|
2019-10-03 09:32:03 +02:00
|
|
|
|
|
|
|
- Print different values based on conditions:
|
|
|
|
|
2020-02-18 05:26:27 +08:00
|
|
|
`awk '{if ($1 == "foo") print "Exact match foo"; else if ($1 ~ "bar") print "Partial match bar"; else print "Baz"}' {{filename}}`
|
2020-11-01 15:42:00 +01:00
|
|
|
|
2022-03-27 07:25:15 +02:00
|
|
|
- Print all lines where the 10th column value equals the specified value:
|
2020-11-01 15:42:00 +01:00
|
|
|
|
|
|
|
`awk '($10 == value)'`
|
|
|
|
|
2022-03-27 07:25:15 +02:00
|
|
|
- Print all the lines which the 10th column value is between a min and a max:
|
2020-11-01 15:42:00 +01:00
|
|
|
|
|
|
|
`awk '($10 >= min_value && $10 <= max_value)'`
|