在元组中查找元素并对其进行过滤
假设我有一个类似的元组:
[('text-1','xxx'), ('img-1','iii'), ('img-2','jjj'), ('text-2','xxx')]
我想过滤出列表并生成一个以’img’开头的元素的新列表。因此,我的新列表将如下所示:
[('img-1','iii'), ('img-2','jjj')]
谢谢!
-
单程:
>>> 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