Какой самый простой способ подсчитать количество вхождений символа в строку?
Например подсчитать, сколько раз 'a'
появляется в 'Mary had a little lamb'
18 ответов
str.count (sub [, start [, end]])
Вернуть количество неперекрывающихся вхождений подстроки
sub
в диапазоне[start, end]
. Необязательные аргументыstart
иend
интерпретируются как обозначения срезов.
>>> sentence = 'Mary had a little lamb'
>>> sentence.count('a')
4
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
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 (), вероятно, является самым простым, но если вы делаете это часто, посмотрите collection.Counter:
from collections import Counter
my_str = "Mary had a little lamb"
counter = Counter(my_str)
print counter['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()
Я фанат библиотеки панд, в частности, метода 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
Регулярные выражения очень полезны, если вы хотите не учитывать регистр (и, конечно, всю мощь регулярных выражений).
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 очень длинная или код находится внутри глубокого цикла.
Python - 3.x :
"aabc".count("a")
str.count (sub [, start [, end]])
Возвращает количество неперекрывающихся вхождений подстроки sub в диапазоне [start, end]. Необязательные аргументы start и end интерпретируются как обозначения срезов.
Эта простая и понятная функция может помочь:
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}
Альтернативный способ получить все количество символов без использования 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'
в данном конкретном случае.
a = 'have a nice day'
symbol = 'abcdefghijklmnopqrstuvwxyz'
for key in symbol:
print key, a.count(key)
Регулярные выражения, может быть?
import re
my_string = "Mary had a little lamb"
len(re.findall("a", my_string))
Не более чем это ИМХО - можно добавить верхний или нижний методы
def count_letter_in_str(string,letter):
return string.count(letter)
str = "count a character occurance"
List = list(str)
print (List)
Uniq = set(List)
print (Uniq)
for key in Uniq:
print (key, str.count(key))
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))
Вы можете использовать count ():
>>> 'Mary had a little lamb'.count('a')
4
Похожие вопросы
Новые вопросы
python
Python - это многопарадигмальный, динамически типизированный, многоцелевой язык программирования. Он разработан для быстрого изучения, понимания и использования, а также для обеспечения чистого и единообразного синтаксиса. Обратите внимание, что Python 2 официально не поддерживается с 01.01.2020. Тем не менее, для вопросов о Python, связанных с версией, добавьте тег [python-2.7] или [python-3.x]. При использовании варианта Python (например, Jython, PyPy) или библиотеки (например, Pandas и NumPy) включите его в теги.