单程:
>>> l = [('text-1','xxx'), ('img-1','iii'), ('img-2','jjj'), ('text-2','xxx')]>>> [t for t in l if t[0].startswith('img')][('img-1', 'iii'), ('img-2', 'jjj')]
另一种方式:
>>> filter(lambda x: x[0].startswith('img'), l)[('img-1', 'iii'), ('img-2', 'jjj')]
第一种称为列表理解。有关相关技术,请参见FC的答案。基本语法为
[{expression}for {item_var_or_vars} in {iterable} if {boolean_expression}]。它在语义上等效于以下内容:
new_list = []for {item_var_or_vars} in {iterable}: if {boolean_expression}: new_list.append({expression})
该
if {boolean_expression}位是可选的,就像在for循环中一样。
第二个是简单的内置函数
filter,它接受测试函数和可迭代函数,并返回一个包含“通过”测试函数的每个元素的列表。
lambda,如果您以前从未看过,那只是定义函数的一种快速方法。您可以改为:
def keep_this_element(element): return element[0].startswith('img') # returns True for ('img...', '...')new_list = filter(keep_this_element, l) # keeps only elements that return True
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)