Nowe posty

xx Dystrybucja pod HP Omen (6)
Wczoraj o 23:30:08
xx [Poradnik] Wyszukiwanie Sterowników (2)
Wczoraj o 21:08:23
lamp Problem z Linux Lite po instalacji (0)
Wczoraj o 19:50:30
xx Ile pingwinów? (1)
Wczoraj o 08:59:24
xx konfiguracja pale moon (0)
2024-03-24, 21:53:42
xx Plasma 6 w Neonie ssie trochę mniej ... (10)
2024-03-23, 02:38:11
xx problem z instalacja sterowników do karty sieciowej (3)
2024-03-18, 18:10:16
xx Plik abc.001 (1)
2024-03-17, 17:48:27
xx Zlecę dopracowanie programu w MatLab (0)
2024-03-13, 15:28:40
xx Linux Mint 21.3 XFCE brak dźwieku po paru minutach (karta muzyczna zintegrowana) (5)
2024-03-12, 23:07:01

Autor Wątek: wyświetlenie przedostatniej linijki pliku tekstowego na różne sposoby  (Przeczytany 1418 razy)

Offline guest013

  • Nowy na forum
  • *
  • Wiadomości: 3
    • Zobacz profil
Witam,
chciałbym prosić o podpowiedź odnośnie tematu tego wątku.
Ogólnie rzecz biorąc wiem jak to wykonać:
tail -2 file.txt | head -1
Jednak próbuję poznać inne sposoby rozwiązania tego problemu. I nie jest to problem w pracy czy na studiach. Ja bawię się bashem hobbystycznie w domu :)

Wyczytałem że można użyć sed, ale nie wyświetla mi przedostatniej, a dwie ostatnie linijki. To tylko moja próba, i do końca nie rozumiem co i jak się tu dzieje, ponieważ sądziłem że sed służy głównie do znalezienia jakiegoś paternu i podmiany na inny (s/from/to).
sed '$!N;$!D' file.txt

Próbowałem także użyć awk ale w tym przypadku nie mam kompletnie czym się pochwalić.

Czy mógłbym liczyć jeśli nawet nie na konkretną odpowiedź to chociaż wskazanie kierunku poszukiwań?
« Ostatnia zmiana: 2021-10-25, 15:23:49 wysłana przez guest013 »

Offline guest013

  • Nowy na forum
  • *
  • Wiadomości: 3
    • Zobacz profil
Zawsze pisząc zapytanie na forach i tak kombinuję, jak samodzielnie rozwiązać swój problem.
Tak też i w tym przypadku, udało mi się poradzić sobie z sedem.
To co potrzebowałem wywołuje poniższe:
sed -n 'x;$p' file.txt

Ale z awk będzie trudniej, i liczę na pomoc ;)

Offline guest013

  • Nowy na forum
  • *
  • Wiadomości: 3
    • Zobacz profil
Idę niczym burza :) i gadam sam do siebie.
Zamieszczam odpowiedzi gdyby ktoś miał podobne pomysły jak jak :)
I oczywiście co chwila jestem troszeczkę lepszy.

Poniżej rozwiązanie łączące sed i awk. sed usuwa ostatnią linijkę, awk printuje (nową) ostatnią linię - czyli starą przedostatnią

sed '$d' file.txt | awk 'END {print}'

Sprawdzę jeszcze czy uda mi się zadanie wykonać dla samego awk

Offline 1709

  • Users
  • Guru
  • *****
  • Wiadomości: 2763
  • 1709
    • Zobacz profil
$ PRZYKLAD=$(echo -e "Linia 1\nLinia 2\nLinia 3\nLinia 4") ; while read -r LINE ; do POPRZEDNIA="$NOWA" ; NOWA="$LINE" ; done <<< "$PRZYKLAD" ; echo "$POPRZEDNIA"
Linia 3

PS: Brak polskiej czcionki, nie jest to brak lenistwa, a jej brak w systemie i brak czasu na reczne poprawki.

Offline 1709

  • Users
  • Guru
  • *****
  • Wiadomości: 2763
  • 1709
    • Zobacz profil
Cytuj
i do końca nie rozumiem co i jak się tu dzieje, ...
sed '$!N;$!D' file.txt

https://linux.die.net/man/1/sed

Prawdopodobnie ...
Cytuj
n N

Read/append the next line of input into the pattern space.
Cytuj
D

Delete up to the first embedded newline in the pattern space. Start next cycle, but skip reading from the input if there is still data in the pattern space.
PS: Brak polskiej czcionki, nie jest to brak lenistwa, a jej brak w systemie i brak czasu na reczne poprawki.