2012-10-20 133 views
1

我想解决类似于下面的更一般的问题。在下面,我得到了vow_array,它表示在一些文本中存在一些元音,比如发送给我的程序。我需要打印每个元音的存在为0或1.python检查列表元素的存在

ch_a = 0 
ch_e = 0 
ch_i = 0 
ch_o = 0 
ch_u = 0 

# vow_array is generated at runtime; here is an example 
vow_array = ['a', 'o', 'u'] 

if 'a' in vow_array: 
    ch_a = ch_a + 1 
if 'e' in vow_array: 
    ch_e = ch_e + 1 
if 'i' in vow_array: 
    ch_i = ch_i + 1 
if 'o' in vow_array: 
    ch_o = ch_o + 1 
if 'u' in vow_array: 
    ch_u = ch_u + 1 

print ch_a, ch_e, ch_i, ch_o, ch_u 

我认为这段代码太长,容易出错。有没有更紧凑的写作方式?另外,如果我必须为字母表中的所有“字母”执行此操作,则我不想重复该代码。

回答

6

当然。

如果你有相同的前缀(ch_ach_e,...),你需要使用字典或列表,以它们分组变量:

vowels = { 
    'a': 0, 
    'e': 0, 
    'i': 0, 
    'o': 0, 
    'u': 0 
} 

vowel_array = ['a', 'o', 'u'] 

for vowel in vowels.keys(): 
    if vowel in vowel_array: 
     vowels[vowel] += 1 

print vowels 

一个更Python的解决办法是什么像这样:

>>> from collections import Counter 
>>> 
>>> letters = 'i am a sentence' 
>>> Counter(letters) 
Counter({' ': 3, 'e': 3, 'a': 2, 'n': 2, 'c': 1, 'i': 1, 'm': 1, 's': 1, 't': 1}) 
+0

+1 - 数据结构是缺少的,“collections.Counter”在这里是正确的。 –

+0

美丽,谢谢!也感谢其他人,对解决方案也有同样的想法。 – user1487178

0

试试这个:

ch_dict = {'a':0,'e':0,'i':0,'o':0,'u':0} 
vow_array = ['a','o','u'] 
for d in vow_array: 
    ch_dict[d] = ch_dict[d] + 1 

print(ch_dict) 
1

相同的思路@Blender的,只是初始化字典不同的方式(你可以用Python中的字典修真> 2.7做到这一点):

>>> vowels = dict((v, 0) for v in 'aeiou') 
>>> vow_array = ['a', 'o', 'u'] 
>>> for vow in vow_array: 
... vowels[vow] += 1 
>>> vowels 
{'e': 0, 'i': 0, 'o': 1, 'u': 1, 'a': 1} 

如果排序是一个问题:

>>> for value in sorted(vowels): 
... print '{0}: {1}'.format(value, vowels[value]) 
... 
a: 1 
e: 0 
i: 0 
o: 1 
u: 1 
相关问题