문자열에서 문자의 발생 횟수를 카운트합니다.
문자열에 포함된 문자의 발생 횟수를 계산하려면 어떻게 해야 합니까?
★★'a'
'Mary had a little lamb'
4인치.
str.count(sub[, start[, end]])
되지 않는 합니다.
sub
[start, end]
인수.start
★★★★★★★★★★★★★★★★★」end
는 슬라이스 표기법으로 해석됩니다.
>>> sentence = 'Mary had a little lamb'
>>> sentence.count('a')
4
다음을 사용할 수 있습니다.
>>> 'Mary had a little lamb'.count('a')
4
모든 문자의 카운트를 취득하려면 , 다음과 같이 사용합니다.
>>> from collections import Counter
>>> counter = Counter("Mary had a little lamb")
>>> counter['a']
4
규칙적인 표현일까요?
import re
my_string = "Mary had a little lamb"
len(re.findall("a", my_string))
Python-3.x:
"aabc".count("a")
[start, end] 범위의 서브스트링 서브의 중복되지 않는 발생 횟수를 반환합니다.옵션의 인수 시작과 끝은 슬라이스 표기법과 같이 해석됩니다.
myString.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
글자의 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
이 간단하고 간단한 기능을 사용하면 다음과 같은 이점이 있습니다.
def check_freq(x):
freq = {}
for c in set(x):
freq[c] = x.count(c)
return freq
check_freq("abbabcbdbabdbdbabababcbcbab")
{'a': 7, 'b': 14, 'c': 3, 'd': 3}
이해가 필요한 경우:
def check_freq(x):
return {c: x.count(c) for c in set(x)}
정규 표현은 대소문자를 구분하지 않는 경우(물론 regex의 모든 검정력)에 매우 유용합니다.
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))
regex 버전은 실행하는 데 10배의 시간이 소요되므로 my_string이 매우 길거나 코드가 딥 루프 내에 있는 경우에만 문제가 될 수 있습니다.
'심플'에 대해서는 잘 모르겠지만 간단한 이해로 할 수 있는 것은 다음과 같습니다.
>>> my_string = "Mary had a little lamb"
>>> sum(char == 'a' for char in my_string)
4
내장된 합계, 생성기 이해 및 bool이 정수의 하위 클래스라는 사실을 이용하여 문자 곱셈이 'a'와 동일한지 확인합니다.
a = 'have a nice day'
symbol = 'abcdefghijklmnopqrstuvwxyz'
for key in symbol:
print(key, a.count(key))
는 판다 판다 도서관 입니다.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
count
는 문자열 내의 문자의 발생을 세는 가장 간결하고 효율적인 방법이지만, 다음과 같은 방법을 사용하여 해결하려고 했습니다.
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'
이 특별한 경우에는요.
사용하지 않고 모든 문자 수를 가져올 수 있는 대체 방법Counter()
,count
및 regex
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)
a = "I walked today,"
c=['d','e','f']
count=0
for i in a:
if str(i) in c:
count+=1
print(count)
특정 글자를 세어보라는 거 알아요.저는 여기에 아무 방법 없이 범용 코드를 쓰고 있습니다.
sentence1 =" Mary had a little lamb"
count = {}
for i in sentence1:
if i in count:
count[i.lower()] = count[i.lower()] + 1
else:
count[i.lower()] = 1
print(count)
산출량
{' ': 5, 'm': 2, 'a': 4, 'r': 1, 'y': 1, 'h': 1, 'd': 1, 'l': 3, 'i': 1, 't': 2, 'e': 1, 'b': 1}
특정 문자 빈도를 원하는 경우 다음과 같이 인쇄할 수 있습니다.
print(count['m'])
2
문장에서 문자의 발생을 찾으려면 아래 코드를 사용할 수 있습니다.
먼저 문장에서 고유한 문자를 꺼낸 다음 빈칸이 있는 문장의 각 문자의 발생을 세어 보았습니다.
ab = set("Mary had a little lamb")
test_str = "Mary had a little lamb"
for i in ab:
counter = test_str.count(i)
if i == ' ':
i = 'Space'
print(counter, i)
상기 코드의 출력은 다음과 같습니다.
1 : r ,
1 : h ,
1 : e ,
1 : M ,
4 : a ,
1 : b ,
1 : d ,
2 : t ,
3 : l ,
1 : i ,
4 : Space ,
1 : y ,
1 : m ,
"문자열에서 원하는 문자를 찾기 위해 카운트를 사용하지 않음" 메서드.
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()
파이썬 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)
가장 쉬운 방법은 한 줄로 코드화하는 것입니다.
'Mary had a little lamb'.count("a")
하지만 이 방법도 사용할 수 있습니다.
sentence ='Mary had a little lamb'
count=0;
for letter in sentence :
if letter=="a":
count+=1
print (count)
str = "count a character occurence"
List = list(str)
print (List)
Uniq = set(List)
print (Uniq)
for key in Uniq:
print (key, str.count(key))
이 사용자의 코멘트를 취득합니다.
import numpy as np
sample = 'samplestring'
np.unique(list(sample), return_counts=True)
출력:
(array(['a', 'e', 'g', 'i', 'l', 'm', 'n', 'p', 'r', 's', 't'], dtype='<U1'),
array([1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 1]))
's'를 선택합니다.다음과 같이 두 어레이의 이 태플을 필터링할 수 있습니다.
a[1][a[0]=='s']
사이드 노트:와 같이 동작합니다.Counter()
의collections
어쨌든 자주 수입하는 숫자만 있는 패키지입니다.대신 단어 목록에서 고유한 단어를 셀 수 있습니다.
이 IMHO 이하 - 상위 또는 하위 메서드를 추가할 수 있습니다.
def count_letter_in_str(string,letter):
return string.count(letter)
루프와 사전을 사용할 수 있습니다.
def count_letter(text):
result = {}
for letter in text:
if letter not in result:
result[letter] = 0
result[letter] += 1
return result
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))
언급URL : https://stackoverflow.com/questions/1155617/count-the-number-of-occurrences-of-a-character-in-a-string
'IT' 카테고리의 다른 글
MySQL과 Node.js (0) | 2022.11.08 |
---|---|
모델에 사용되는 Larabel의 원시 DB 쿼리에 매개 변수를 바인딩하려면 어떻게 해야 합니까? (0) | 2022.11.08 |
JavaScript에서 CSS 클래스를 동적으로 생성하여 적용하는 방법 (0) | 2022.11.08 |
$에 대한 경고HTTP_RAW_POST_DATA가 폐지되었습니다. (0) | 2022.11.08 |
이미 구축된 Vue JS 앱에 매개 변수를 전달하려면 어떻게 해야 합니까? (0) | 2022.11.08 |