我有一个数字数组,我改为字符串
a="1423" astr=str(a) aspl=list(astr)
我应该有['1','4','2','3'].我想计算阵列中有多少1~9个,这样1 = 1次(s),2 = 1次(s)... 5 = 0次(s),6 = 0次(s). ..
我对此的解决方案是
r=0 for r > 11: b = aspl.count(r)
但由于它是一个字符串,这种方法不起作用.我试过用
b = aspl.count('r')
然后你可能已经猜到了,它只是在寻找r.那你怎么会这样呢?
提前致谢.
python collections
模块提供了一个Counter
:
from collections import Counter a = '032143487214093120' count = Counter(a) print(count) # Counter({'2': 3, '4': 3, '1': 3, '0': 3, '3': 3, '9': 1, '7': 1, '8': 1})
然后打印
for digit in (str(i) for i in range(10)): print('{}: {}x'.format(digit, count[digit])) # 0: 3x # 1: 3x # ... # 5: 0x # ...
如果你坚持在你的字符串中没有出现的数字出现在计数器中,你可以初始化计数器将所有数字设置为零:
count = Counter({str(i): 0 for i in range(10)}) print(count) # Counter({'2': 0, '4': 0, '9': 0, '0': 0, '8': 0, '3': 0, # '1': 0, '7': 0, '5': 0, '6': 0}) count.update(a) print(count) # Counter({'2': 3, '4': 3, '0': 3, '3': 3, '1': 3, '9': 1, # '8': 1, '7': 1, '5': 0, '6': 0})