วิธีที่ง่ายที่สุดในการนับจำนวนที่เกิดขึ้นของตัวละครในสตริงคืออะไร?
เช่นนับจำนวนครั้งที่'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
คุณสามารถใช้การนับ () :
>>> 'Mary had a little lamb'.count('a')
4
ในฐานะที่เป็นคำตอบอื่น ๆ กล่าวว่าการใช้วิธีการนับสตริง () น่าจะเป็นง่าย แต่ถ้าคุณกำลังทำเช่นนี้บ่อยตรวจสอบcollections.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');
ข้อมูลเพิ่มเติมที่นี่
หลาม 3.x:
"aabc".count("a")
str.count (sub [, start [, end]])
ส่งคืนจำนวนการเกิดซับสตริงย่อยที่ไม่ทับซ้อนกันในช่วง [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
สำหรับตัวนับที่ไม่คำนึงถึงขนาดตัวพิมพ์คุณสามารถแทนที่เมธอด mutator และ accessor โดยการทำ subclassing 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
เป็นอ้วนมากขึ้นระดับหลามบริสุทธิ์และdefaultdict
's __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
ไม่ใช่ประเภทในตัวอีกต่อไป นอกจากนี้คุณกำลังนับสิบสี่ของสิบสี่ครั้ง คุณสามารถหลีกเลี่ยงที่เพียงโดยการเปลี่ยนด้วยfor c in text
for c in set(text)
นิพจน์ทั่วไปนั้นมีประโยชน์มากหากคุณต้องการตัวพิมพ์เล็กและตัวพิมพ์ใหญ่ (และแน่นอนว่าพลังทั้งหมดของ 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 ใช้เวลาในการรันนานสิบเท่าซึ่งน่าจะเป็นปัญหาเฉพาะเมื่อ my_string ยาวมากหรือรหัสอยู่ในลูปลึก
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
และ 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)
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))
Python 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)
ไม่เกิน IMHO นี้ - คุณสามารถเพิ่มวิธีการบนหรือล่าง
def count_letter_in_str(string,letter):
return string.count(letter)