Какой самый простой способ подсчитать количество вхождений символа в строку?
например. подсчитайте количество раз 'a' в 'Mary had a little lamb'
Какой самый простой способ подсчитать количество вхождений символа в строку?
например. подсчитайте количество раз '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(), вероятно, самое простое, но если вы делаете это часто, посмотрите collection.Counter:
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');
подробнее здесь
"aabc".count("a")
 str.count(a) - лучшее решение для подсчета одного символа в строке. Но если вам нужно посчитать больше символов, вам придется читать всю строку столько раз, сколько символов вы хотите посчитать.
Лучшим подходом для этой работы будет:
from collections import defaultdict
text = 'Mary had a little lamb'
chars = defaultdict(int)
for char in text:
    chars[char] += 1
 Таким образом, у вас будет dict, который возвращает количество вхождений каждой буквы в строке и 0 если ее нет.
>>>chars['a']
4
>>>chars['x']
0
 Для нечувствительного к регистру счетчика вы можете переопределить методы мутатора и метода defaultdict подкласс defaultdict (базовый класс 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
Регулярные выражения очень полезны, если вы хотите нечувствительность к регистру (и, конечно, всю силу регулярного выражения).
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 чрезвычайно длинна или код находится внутри глубокого цикла.
Эта простая и понятная функция может помочь:
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}
a = 'have a nice day'
symbol = 'abcdefghijklmnopqrstuvwxyz'
for key in symbol:
    print key, a.count(key)
str = "count a character occurance"
List = list(str)
print (List)
Uniq = set(List)
print (Uniq)
for key in Uniq:
    print (key, str.count(key))
Альтернативный способ получить все количество символов без использования Counter(), count и регулярных выражений
counts_dict = {}
for c in list(sentence):
  if c not in counts_dict:
    counts_dict[c] = 0
  counts_dict[c] += 1
for key, value in counts_dict.items():
    print(key, value)
  count - это, безусловно, самый сжатый и эффективный способ подсчета появления символа в строке, но я попытался найти решение с помощью  lambda, что-то вроде этого:
sentence = 'Mary had a little lamb'
sum(map(lambda x : 1 if 'a' in x else 0, sentence))
Это приведет к:
4
Кроме того, есть еще одно преимущество в том, что предложение представляет собой список подстрок, содержащий те же символы, что и выше, а также это дает правильный результат из-за использования in. Посмотрите:
sentence = ['M', 'ar', 'y', 'had', 'a', 'little', 'l', 'am', 'b']
sum(map(lambda x : 1 if 'a' in x else 0, sentence))
Это также приводит к:
4
Но, конечно, это будет работать только при проверке появления одиночного символа, такого как 'a' в этом конкретном случае.
"Без использования счетчика, чтобы найти нужный символ в строке" метод.
import re
def count(s, ch):
   pass
def main():
   s = raw_input ("Enter strings what you like, for example, 'welcome': ")  
   ch = raw_input ("Enter you want count characters, but best result to find one character: " )
   print ( len (re.findall ( ch, s ) ) )
main()
spam = 'have a nice day'
var = 'd'
def count(spam, var):
    found = 0
    for key in spam:
        if key == var:
            found += 1
    return found
count(spam, var)
print 'count %s is: %s ' %(var, count(spam, var))
Не более, чем это IMHO - вы можете добавить верхний или нижний метод
def count_letter_in_str(string,letter):
    return string.count(letter)
Python 3
Есть два способа добиться этого:
1) Со встроенной функцией count()
sentence = 'Mary had a little lamb'
print(sentence.count('a'))'
2) Без использования функции
sentence = 'Mary had a little lamb'    
count = 0
for i in sentence:
    if i == "a":
        count = count + 1
print(count)
Используя Count:
string = "count the number of counts in string to count from."
x = string.count("count")
х = 3.
Это даст вам появление каждого символа в строке. O/P также находится в строчном формате:
def count_char(string1):
string2=""
lst=[]
lst1=[]
for i in string1:
    count=0
    if i not in lst:
        for j in string1:
            if i==j:
                count+=1
        lst1.append(i)
        lst1.append(count)
    lst.append(i)
string2=''.join(str(x) for x in lst1)
return string2 
print count_char("aabbacddaabbdsrchhdsdg")