답변:
grep -o "[0-9] errors" verification_report_3.txt | awk '{ SUM += $1} END { print SUM }'
그것은 목록을 인쇄하지 않지만 합계를 인쇄합니다. 목록과 합계를 모두 원한다면 다음을 수행하십시오.
grep -o "[0-9] errors" verification_report_3.txt | awk '{ SUM += $1; print $1} END { print SUM }'
variable=$(grep -o "[0-9] errors" verification_report_3.txt | awk '{ SUM += $1} END { print SUM }')
이것은 명령의 출력 (합계 값만)을 변수라는 변수에 넣습니다variable
"[0-9]\+ errors"
. > 9 오류를보고하는 회선이있는 경우 일치합니다.
GNU 시스템을 사용하고있는 것 같습니다 . 따라서 Perl 정규 표현식 지원이 가능하면 다음과 같이 작성할 수 있습니다.
grep -Po '[0-9]+(?=\s+errors)' infile |
paste -sd+ |
bc
추신 : 나는 숫자> 9를 허용하도록 정규식을 수정했습니다 (+ 수량 자 추가).
추신 : 또는 awk이면 충분합니다 ( GNU awk 가정 ).
awk 'END { print s }
/[0-9]+[[:space:]]+errors/ {
s += $1
}' infile
grep의 출력을 파이프에 연결하십시오
awk 'BEGIN {total=0;}{total+=$1;}END {print "Total: ",total}'
나는 이것을 사용한다 :
$ echo $(cat file | sed 's/$/+/') 0 | bc
큰 목록에는 효율적이지 않지만 대부분의 유스 케이스에는 좋습니다. 일반적으로 프로세스를 자동화하기 위해 쉘 함수를 사용하므로 파일 이름 만 제공하면됩니다.
## cheezy summation
## call from .bashrc
##
getsum () { echo $(cat $1 | sed 's/$/+/') 0 | bc; }
gethsum () { echo $(cat $1 | sed 's/[gG]/*1000M/' | sed 's/[mM]/*1000K/' | sed 's/[kK]/*1000/' | sed 's/$/+/') 0 | bc; }
gethexsum () { echo ibase=16 $(cat $1 | sed 's/$/+/') 0 | bc; }
데이터가 다른 방식으로 구분 된 경우 특정 요소 구분 기호 나 문자 클래스를 줄 끝 마커로 대체 할 수 있습니다.