[python] 문자열에서 문자 발생 횟수를 센다

문자열에서 문자 발생 횟수를 계산하는 가장 간단한 방법은 무엇입니까?

예를 들면 배의 수 계산 'a'에 나타납니다'Mary had a little lamb'



답변

str.count (sub [, start [, end]])

sub범위에서 겹치지 않는 부분 문자열 수를 리턴합니다 [start, end]. 선택적 인수 start이며 end슬라이스 표기법으로 해석됩니다.

>>> sentence = 'Mary had a little lamb'
>>> sentence.count('a')
4


답변

count () 사용할 수 있습니다 :

>>> 'Mary had a little lamb'.count('a')
4


답변

다른 답변에서 말했듯이 count () 문자열 메서드를 사용하는 것이 가장 간단하지만 자주 수행하는 경우 컬렉션을 확인하십시오 .

from collections import Counter
my_str = "Mary had a little lamb"
counter = Counter(my_str)
print counter['a']


답변

정규 표현식일까요?

import re
my_string = "Mary had a little lamb"
len(re.findall("a", my_string))


답변

myString.count('a');

더 많은 정보는 여기에


답변

파이썬 -3.x :

"aabc".count("a")

str.count (sub [, start [, end]])

[start, end] 범위에서 하위 문자열 하위의 겹치지 않는 횟수를 반환합니다. 선택적 인수 start 및 end는 슬라이스 표기법으로 해석됩니다.


답변

str.count(a)문자열에서 단일 문자를 계산하는 가장 좋은 솔루션입니다. 그러나 더 많은 문자를 계산해야하는 경우 계산하려는 문자 수만큼 문자열 전체를 읽어야합니다.

이 작업에 대한 더 나은 접근 방식은 다음과 같습니다.

from collections import defaultdict

text = 'Mary had a little lamb'
chars = defaultdict(int)

for char in text:
    chars[char] += 1

따라서 문자열에있는 모든 문자의 발생 횟수와 0존재하지 않는 경우 를 반환하는 dict이 있습니다.

>>>chars['a']
4
>>>chars['x']
0

대소 문자를 구분하지 않는 카운터의 경우 서브 클래 싱을 통해 뮤 테이터 및 접근 자 메서드를 재정의 할 수 있습니다 defaultdict(기본 클래스의 메서드 는 읽기 전용 임).

class CICounter(defaultdict):
    def __getitem__(self, k):
        return super().__getitem__(k.lower())

    def __setitem__(self, k, v):
        super().__setitem__(k.lower(), v)


chars = CICounter(int)

for char in text:
    chars[char] += 1

>>>chars['a']
4
>>>chars['M']
2
>>>chars['x']
0