2020-04-15 16:54:29 +01:00
|
|
|
# awk
|
|
|
|
|
2020-04-15 17:39:17 +01:00
|
|
|
> Wszechstronny język programowania do pracy na plikach.
|
|
|
|
> Więcej informacji: <https://github.com/onetrueawk/awk>.
|
2020-04-15 16:54:29 +01:00
|
|
|
|
2020-04-15 17:39:17 +01:00
|
|
|
- Wydrukuj piątą kolumnę (aka. pole) w pliku oddzielonym spacjami:
|
2020-04-15 16:54:29 +01:00
|
|
|
|
2020-04-15 23:21:26 +01:00
|
|
|
`awk '{print $5}' {{nazwapliku}}`
|
2020-04-15 16:54:29 +01:00
|
|
|
|
2020-04-15 17:39:17 +01:00
|
|
|
- Wydrukuj drugą kolumnę wierszy zawierających "something" w pliku oddzielonym spacjami:
|
2020-04-15 16:54:29 +01:00
|
|
|
|
2020-04-15 23:21:26 +01:00
|
|
|
`awk '/{{coś}}/ {print $2}' {{nazwapliku}}`
|
2020-04-15 16:54:29 +01:00
|
|
|
|
2020-04-15 17:39:17 +01:00
|
|
|
- Wydrukuj ostatnią kolumnę każdego wiersza w pliku, używając przecinka (zamiast spacji) jako separatora pola:
|
2020-04-15 16:54:29 +01:00
|
|
|
|
2020-04-15 23:21:26 +01:00
|
|
|
`awk -F ',' '{print $NF}' {{nazwapliku}}`
|
2020-04-15 16:54:29 +01:00
|
|
|
|
2020-04-15 17:39:17 +01:00
|
|
|
- Zsumuj wartości w pierwszej kolumnie pliku i wydrukuj sumę:
|
2020-04-15 16:54:29 +01:00
|
|
|
|
2020-04-15 23:21:26 +01:00
|
|
|
`awk '{s+=$1} END {print s}' {{nazwapliku}}`
|
2020-04-15 16:54:29 +01:00
|
|
|
|
2020-04-15 17:39:17 +01:00
|
|
|
- Drukuj co trzeci wiersz, zaczynając od pierwszego wiersza:
|
2020-04-15 16:54:29 +01:00
|
|
|
|
2020-04-15 23:21:26 +01:00
|
|
|
`awk 'NR%3==1' {{nazwapliku}}`
|
2020-04-15 16:54:29 +01:00
|
|
|
|
2020-04-15 17:39:17 +01:00
|
|
|
- Wydrukuj różne wartości w zależności od warunków:
|
2020-04-15 16:54:29 +01:00
|
|
|
|
2020-04-15 23:21:26 +01:00
|
|
|
`awk '{if ($1 == "foo") print "Dokładne dopasowanie foo"; else if ($1 ~ "bar") print "Częściowe dopasowanie bar"; else print "Baz"}' {{nazwapliku}}`
|
2024-01-01 18:53:36 +00:00
|
|
|
|
|
|
|
- Wydrukuj wszystkie linie gdzie wartość 10-tej kolumny jest równa podanej wartości:
|
|
|
|
|
|
|
|
`awk '($10 == {{wartość}})'`
|
|
|
|
|
|
|
|
- Wydrukuj wszystkie linie, w których wartość 10-tej kolumny jest pomiędzy podanymi wartościami:
|
|
|
|
|
|
|
|
`awk '($10 >= {{wartość_minimalna}} && $10 <= {{wartość_maksymalna}})'`
|