echo -e 'one two three\nfour five six\nseven eight nine'
one two three
four five six
seven eight nine
이 출력을 얻기 위해 어떻게 "마법"을 사용할 수 있습니까? :
three
six
nine
업데이트: 이 특정 방법은 필요하지 않습니다. 행에 몇 개의 열이 있든 상관없이 일반적인 솔루션이 필요합니다. 예: awk는 항상 마지막 열을 표시합니다.
답변1
노력하다:
echo -e 'one two three\nfour five six\nseven eight nine' | awk '{print $NF}'
답변2
생각보다 쉽습니다.
$ echo one two three | awk '{print $NF}'
three
답변3
시도해 보세요(더 짧고 간단하지만 regex 사용으로 인해 grep
3배 느림 ).awk
grep -o '\S\+$' <(echo -e '... seven eight nine')
또는 ex
(더 느리지만 완료되면 전체 버퍼를 인쇄하므로 제자리에서 정렬하거나 편집해야 할 때 더 유용합니다):
ex -s +'%s/^.*\s//g' -c'%p|q!' <(echo -e '... seven eight nine')
ex +'%norm $Bd0' -sc'%p|q!' infile
제자리로 바꾸려면 로 바꾸 -sc'%p|q!'
십시오 -scwq
.
또는 bash
:
while read line; do arr=($line); echo ${arr[-1]}; done < someinput
성능
다음을 통해 1GB 파일을 생성합니다.
$ hexdump -C /dev/urandom | rev | head -c1G | pv > datafile
구문 분석 시간 통계를 수행했습니다(약 3번 실행하여 MBP OS X에서 테스트하여 가장 낮은 값을 얻었습니다).
사용
awk
:$ time awk '{print $NF}' datafile > /dev/null real 0m12.124s user 0m10.704s sys 0m0.709s
사용
grep
:$ time grep -o '\S\+$' datafile > /dev/null real 0m36.731s user 0m36.244s sys 0m0.401s $ time grep -o '\S*$' datafile > /dev/null real 0m40.865s user 0m39.756s sys 0m0.415s
사용
perl
:$ time perl -lane 'print $F[-1]' datafile > /dev/null real 0m48.292s user 0m47.601s sys 0m0.396s
rev
+를 사용하세요cut
:$ time (rev|cut -d' ' -f1|rev) < datafile > /dev/null $ time rev datafile | cut -d' ' -f1 | rev > /dev/null real 1m10.342s user 1m19.940s sys 0m1.263s
사용
ex
:$ time ex +'%norm $Bd0_' -sc'%p|q!' datafile > /dev/null real 3m47.332s user 3m42.037s sys 0m2.617s $ time ex +'%norm $Bd0' -sc'%p|q!' datafile > /dev/null real 4m1.527s user 3m44.219s sys 0m6.164s $ time ex +'%s/^.*\s//g' -sc'%p|q!' datafile > /dev/null real 4m16.717s user 4m5.334s sys 0m5.076s
사용
bash
:$ time while read line; do arr=($line); echo ${arr[-1]}; done < datafile > /dev/null real 9m42.807s user 8m12.553s sys 1m1.955s
답변4
... | perl -lane 'print $F[-1]'