Подсчитать количество вхождений символа в строку - PullRequest
864 голосов
/ 21 июля 2009

Какой самый простой способ подсчитать количество вхождений символа в строку?

например. считать количество раз, 'a' появляется в 'Mary had a little lamb'

Ответы [ 18 ]

1212 голосов
/ 21 июля 2009

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

Возвращает количество неперекрывающихся вхождений подстроки sub в диапазоне [start, end]. Необязательные аргументы start и end интерпретируются как обозначения срезов.

>>> sentence = 'Mary had a little lamb'
>>> sentence.count('a')
4
133 голосов
/ 21 июля 2009

Вы можете использовать count () :

>>> 'Mary had a little lamb'.count('a')
4
96 голосов
/ 02 августа 2012

Как и в других ответах, использование строкового метода count (), вероятно, является самым простым, но если вы делаете это часто, посмотрите collection.Counter :

from collections import Counter
my_str = "Mary had a little lamb"
counter = Counter(my_str)
print counter['a']
48 голосов
/ 21 июля 2009

Регулярные выражения, может быть?

import re
my_string = "Mary had a little lamb"
len(re.findall("a", my_string))
24 голосов
/ 21 июля 2009
myString.count('a');

подробнее здесь

15 голосов
/ 21 июля 2009
"aabc".count("a")
12 голосов
/ 02 октября 2016

str.count(a) - лучшее решение для подсчета одного символа в строке. Но если вам нужно подсчитать больше символов, вам нужно будет прочитать всю строку столько раз, сколько символов вы хотите посчитать.

Лучший подход к этой работе:

from collections import defaultdict

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

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

Таким образом, у вас будет диктант, который возвращает количество вхождений каждой буквы в строке и 0, если ее нет.

>>>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
9 голосов
/ 20 марта 2018

Эта простая и понятная функция может помочь:

def check_freq(str):
    freq = {}
    for c in str:
       freq[c] = str.count(c)
    return freq

check_freq("abbabcbdbabdbdbabababcbcbab")
{'a': 7, 'b': 14, 'c': 3, 'd': 3}
9 голосов
/ 05 декабря 2014

Регулярные выражения очень полезны, если вам нужна нечувствительность к регистру (и, конечно, вся мощь регулярных выражений).

my_string = "Mary had a little lamb"
# simplest solution, using count, is case-sensitive
my_string.count("m")   # yields 1
import re
# case-sensitive with regex
len(re.findall("m", my_string))
# three ways to get case insensitivity - all yield 2
len(re.findall("(?i)m", my_string))
len(re.findall("m|M", my_string))
len(re.findall(re.compile("m",re.IGNORECASE), my_string))

Имейте в виду, что версия регулярного выражения выполняется в десять раз дольше, что, вероятно, будет проблемой, только если my_string очень длинная или код находится внутри глубокого цикла.

5 голосов
/ 25 октября 2015
a = 'have a nice day'
symbol = 'abcdefghijklmnopqrstuvwxyz'
for key in symbol:
    print key, a.count(key)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...