Ich habe eine Datei, die die folgenden drei Zeilen enthält. Ich möchte die vorletzte Zeile abrufen, d. H. 100.000;8438; 06:46:12
.
.
.
.
99.900; 8423; 06:44:41
100.000;8438; 06:46:12
Number of patterns: 8438
Ich kenne die Zeilennummer nicht. Wie kann ich es mit einem Shell-Skript abrufen? Vielen Dank im Voraus für Ihre Hilfe.
Versuche dies:
tail -2 yourfile | head -1
ed
und sed
können das auch.
str='
99.900; 8423; 06:44:41
100.000;8438; 06:46:12
Number of patterns: 8438
'
printf '%s' "$str" | sed -n -e '${x;1!p;};h' # print last line but one
printf '%s\n' H '$-1p' q | ed -s <(printf '%s' "$str") # same
printf '%s\n' H '$-2,$-1p' q | ed -s <(printf '%s' "$str") # print last line but two
Ein kurzer Einleiner, inspiriert von https://stackoverflow.com/a/7671772/5287901
sed -n 'x;$p'
Erläuterung:
-n
quiet mode: druckt den Musterbereich nicht automatischx
: Tauschen Sie den Pattern-Space und den Hold-Space aus.$
: In der letzten Zeile p
: Druckt den Musterbereich (die vorherige Zeile, in diesem Fall die vorletzte Zeile).Benutze das
tail -2 <filename> | head -1
Von: Nützliche sed Einleiner von Eric Pement
# print the next-to-the-last line of a file
sed -e '$!{h;d;}' -e x # for 1-line files, print blank line
sed -e '1{$q;}' -e '$!{h;d;}' -e x # for 1-line files, print the line
sed -e '1{$d;}' -e '$!{h;d;}' -e x # for 1-line files, print nothing
Sie brauchen nicht alle, wählen Sie einfach eine aus.
Um zu klären, was bereits gesagt wurde:
ec2thisandthat | sort -k 5 | grep 2012- | awk '{print $2}' | tail -2 | head -1
snap-e8317883
snap-9c7227f7
snap-5402553f
snap-3e7b2c55
snap-246b3c4f
snap-546a3d3f
snap-2ad48241
snap-d00150bb
kehrt zurück
snap-2ad48241
tac <file> | sed -n '2p'