1行(または常に1行しかないため、すべての行)にある一致の数を数えたいと思います。
次のように、1行に1つの一致だけではなく、カウントしたい
echo "123 123 123" | grep -c -E "123" # Result: 1
より良い例:
echo "1 1 2 2 2 5" | grep -c -E '([^ ])( \1){1}' # Result: 1, expected: 2 or 3
grep -o
次に、パイプスルーを使用できますwc -l
:
$ echo "123 123 123" | grep -o 123 | wc -l
3
最初にスペースを改行に変換する必要があるかもしれません:
$ echo "1 1 2 2 2 5" | tr ' ' $'\n' | grep -c 2
3
たぶん以下:
echo "123 123 123" | sed "s/123 /123\n/g" | wc -l
(醜いかもしれませんが、私のbash fuはそれほど素晴らしいものではありません)