[bash] Bash를 사용하여 문자열에서 문자 발생 횟수 계산

Bash를 사용하여 문자열에서 문자의 발생 횟수를 계산해야합니다 .

다음 예에서, 숯 인 경우 (예) t, 그 echo이야 의 발생의 정확한 개수 t하여 var있지만, 문자 또는 쉼표 세미콜론되면 제로 출력한다 :

var = "text,text,text,text" 
num = `expr match $var [,]`
echo "$num"



답변

다음 awk명령을 사용합니다 .

string="text,text,text,text"
char=","
awk -F"${char}" '{print NF-1}' <<< "${string}"

문자열을 분할하고 $char결과 필드 수에서 1을 뺀 값을 인쇄합니다.

쉘이 <<<연산자를 지원하지 않는 경우 다음을 사용하십시오 echo.

echo "${string}" | awk -F"${char}" '{print NF-1}'


답변

예를 들어 다음과 같이 다른 모든 문자를 제거하고 남은 것을 계산할 수 있습니다.

var="text,text,text,text"
res="${var//[^,]}"
echo "$res"
echo "${#res}"

인쇄됩니다

,,,
3

또는

tr -dc ',' <<<"$var" | awk '{ print length; }'

또는

tr -dc ',' <<<"$var" | wc -c    #works, but i don't like wc.. ;)

또는

awk -F, '{print NF-1}' <<<"$var"

또는

grep -o ',' <<<"$var" | grep -c .

또는

perl -nle 'print s/,//g' <<<"$var"


답변

trwc명령 을 결합하여 수행 할 수 있습니다 . 예를 들어, e문자열에서 계산 하려면 referee

echo "referee" | tr -cd 'e' | wc -c

산출

4

설명 : Command tr -cd 'e'는 ‘e’이외의 모든 문자를 제거하고 Command wc -c는 나머지 문자를 계산합니다.

여러 줄의 입력도이 솔루션에 적합합니다. 예를 들어 command cat mytext.txt | tr -cd 'e' | wc -ccan counts ein the file mytext.txt과 같이 파일에 여러 줄이 포함될 수 있다고 생각할 수도 있습니다.


답변

모든 사람의 훌륭한 답변과 댓글을 바탕으로 가장 짧고 달콤한 버전입니다.

grep -o "$needle" <<< "$haystack" | wc -l


답변

awk는 서버에 있으면 잘 작동합니다.

var="text,text,text,text" 
num=$(echo "${var}" | awk -F, '{print NF-1}')
echo "${num}"


답변

다음을 제안합니다.

var="any given string"
N=${#var}
G=${var//g/}
G=${#G}
(( G = N - G ))
echo "$G"

다른 프로그램에 대한 호출 없음


답변

예를 들어 우리는 t

echo "test" | awk -v RS='t' 'END{print NR-1}'

또는 python

python -c 'print "this is for test".count("t")'

또는 더 나은 방법으로 스크립트를 동적으로 만들 수 있습니다. awk

echo 'test' | awk '{for (i=1 ; i<=NF ; i++) array[$i]++ } END{ for (char in array) print char,array[char]}' FS=""

이 경우 출력은 다음과 같습니다.

e 1
s 1
t 2