tldr/pages.pl/common/awk.md

37 lines
1.2 KiB
Markdown
Raw Normal View History

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}}`
- 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}})'`