目前,我有这个:
lst = ['Eleanor', 'Sammy', 'Owen', 'Gavin']
def partition(lst):
if any('abcdefghijklm') in ([x[0] for x in lst]):
print(lst)
else:
print('This still isn\'t working')
我正在尝试检查lst中每个字符串的第一个字符,并且只打印lst中以任何字母A-M开头的字符串。我似乎找不到任何支持它的方法。有没有我忽略的原生方法?
答案 0 :(得分:1)
lst = ['Eleanor', 'Sammy', 'Owen', 'Gavin']
whitelist = set('abcdefghijklm')
for name in lst:
if name[0].lower() in whitelist:
print(name)
答案 1 :(得分:1)
你误解了any
的作用。如果提供给它的可迭代的任何成员为True,则返回True:print(any([False, [], 0, None, 'a'])) #outputs True
相反,all
仅在传递给它的迭代的每个成员为True时返回True。 / p>
然而,它是一个功能强大的工具,您可以使用此任务:
from string import ascii_lowercase as lowercase #a-z
def partition(*names):
if any(n[0].lower() in lowercase[:13] for n in names):
print(*names)
else:
print("No names matched the criteria")
partition('Eleanor', 'Sammy', 'Owen', 'Gavin')
答案 2 :(得分:0)
如此简单明了:
def partition(lst):
print([ x for x in lst if x[0].lower() in 'abcdefghijklm' ])
或者说非常清楚:
def partition(lst):
for word in lst:
if word[0] in 'abcdefghijklm':
print(word)