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

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

1120
Mat 21 Июл 2009 в 00:00

18 ответов

Лучший ответ

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

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

>>> sentence = 'Mary had a little lamb'
>>> sentence.count('a')
4
1303
wjandrea 1 Дек 2016 в 07:16

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
13
Nuno André 22 Июл 2018 в 14:16

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)
-1
Dipen Bakraniya 7 Сен 2019 в 20:16

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

from collections import Counter
my_str = "Mary had a little lamb"
counter = Counter(my_str)
print counter['a']
108
julienc 8 Мар 2019 в 15:50

Метод «Без использования счетчика, чтобы найти нужный символ в строке».

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()
0
Sebastian Palma 7 Фев 2018 в 22:49

Я фанат библиотеки панд, в частности, метода value_counts(). Вы можете использовать его для подсчета появления каждого символа в вашей строке:

>>> import pandas as pd
>>> phrase = "I love the pandas library and its `value_counts()` method"
>>> pd.Series(list(phrase)).value_counts()
     8
a    5
e    4
t    4
o    3
n    3
s    3
d    3
l    3
u    2
i    2
r    2
v    2
`    2
h    2
p    1
b    1
I    1
m    1
(    1
y    1
_    1
)    1
c    1
dtype: int64
0
Sébastien Wieckowski 19 Янв 2020 в 09:23

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

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 очень длинная или код находится внутри глубокого цикла.

9
jafelds 5 Дек 2014 в 17:04

Python - 3.x :

"aabc".count("a")

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

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

15
tremendows 14 Янв 2020 в 19:38

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

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

check_freq("abbabcbdbabdbdbabababcbcbab")
{'a': 7, 'b': 14, 'c': 3, 'd': 3}
10
Chromazmoves 9 Фев 2020 в 07:23

Альтернативный способ получить все количество символов без использования 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)
2
Syed Shamikh Shabbir 7 Мар 2019 в 09:09

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' в данном конкретном случае.

1
Satish Garg 28 Мар 2017 в 17:22
a = 'have a nice day'
symbol = 'abcdefghijklmnopqrstuvwxyz'
for key in symbol:
    print key, a.count(key)
5
josliber 24 Окт 2015 в 22:37

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

import re
my_string = "Mary had a little lamb"
len(re.findall("a", my_string))
48
Sinan Taifour 20 Июл 2009 в 20:03

Не более чем это ИМХО - можно добавить верхний или нижний методы

def count_letter_in_str(string,letter):
    return string.count(letter)
-2
Tim Seed 23 Фев 2016 в 19:16
myString.count('a');

здесь ...

25
Finer Recliner 20 Июл 2009 в 20:04
str = "count a character occurance"

List = list(str)
print (List)
Uniq = set(List)
print (Uniq)

for key in Uniq:
    print (key, str.count(key))
2
Darwin von Corax 1 Апр 2016 в 02:36
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))
-1
poolie 15 Ноя 2015 в 19:09

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

>>> 'Mary had a little lamb'.count('a')
4
144
Kewin Dousse 5 Окт 2016 в 07:24