Korzystanie z AWKAWK
- to najprostsze, jakie można uzyskać:
awk '/yellow/,0' textfile.txt
Przykładowy przebieg
$ awk '/yellow/,0' textfile.txt
yellow
red
orange
more orange
more blue
this is enough
Grep
Można również skorzystać grep
z --after-context
opcji, aby wydrukować pewną ilość wierszy po meczu
grep 'yellow' --after-context=999999 textfile.txt
Do automatycznego ustawienia kontekstu możesz użyć $(wc -l textfile.txt)
. Podstawową ideą jest to, że jeśli masz pierwszy wiersz jako dopasowanie i chcesz wydrukować wszystko po tym dopasowaniu, musisz znać liczbę wierszy w pliku minus 1. Na szczęście --after-context
nie wyrzuci błędów dotyczących liczby linii, więc możesz podać jej liczbę całkowicie poza zasięgiem, ale w przypadku, gdy jej nie znasz, zrobi to całkowita liczba linii
$ grep 'yellow' --after-context=$(wc -l < textfile.txt) textfile.txt
yellow
red
orange
more orange
more blue
this is enough
Jeśli chcesz skrócić, polecenie --after-context
jest takie samo, jak -A
i $(wc -l textfile.txt)
, zostanie rozszerzone do liczby wierszy, po których następuje nazwa pliku. W ten sposób piszesz textfile.txt
tylko raz
grep "yellow" -A $(wc -l textfile.txt)
Pyton
skolodya@ubuntu:$ ./printAfter.py textfile.txt
yellow
red
orange
more orange
more blue
this is enough
DIR:/xieerqi
skolodya@ubuntu:$ cat ./printAfter.py
#!/usr/bin/env python
import sys
printable=False
with open(sys.argv[1]) as f:
for line in f:
if "yellow" in line:
printable=True
if printable:
print line.rstrip('\n')
Lub alternatywnie bez printable
flagi
#!/usr/bin/env python
import sys
with open(sys.argv[1]) as f:
for line in f:
if "yellow" in line:
for lines in f: # will print remaining lines
print lines.rstrip('\n')
exit()
grep
polecenie dogrep "yellow" -A $(wc -l textfile.txt)
.