Відповіді:
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 (), мабуть, найпростіший, але якщо ви робите це часто, перегляньте колекції.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))
len(re.findall('1',bin(10)))
myString.count('a');
Більше інформації тут
Python-3.x:
"aabc".count("a")
str.count (sub [, 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
якщо її немає.
>>>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
Counter
, що вже є класом у collections
.
Counter
є більш роздутим чистим класом Python і defaultdict
«и __missing__
це написано в C . Для такої простої задачі ( int
яка також реалізується в C) такий підхід є плавно швидшим.
Ця легка та пряма функція вперед може допомогти:
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}
str
. Якщо ви даєте його ім'я змінній, str
це вже не вбудований тип. Також ви рахуєте чотирнадцять b чотирнадцять разів. Ви можете уникнути цього , просто змінивши for c in text
з for c in set(text)
.
Регулярні вирази дуже корисні, якщо ви хочете нечутливості до випадків (і, звичайно, всієї сили регулярного вираження).
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 надзвичайно довгий або код знаходиться в глибокому циклі.
a = 'have a nice day'
symbol = 'abcdefghijklmnopqrstuvwxyz'
for key in symbol:
print key, a.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()
Я прихильник бібліотеки панди, зокрема 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
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))
Пітон 3
Це два способи досягти цього:
1) З вбудованим числом функцій ()
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)