2011-08-17 51 views
6

假设我有这样一个元组:查找在一个元组元素,并筛选他们

[('text-1','xxx'), ('img-1','iii'), ('img-2','jjj'), ('text-2','xxx')] 

我想筛选出的名单,并产生一个新的有与“IMG”开头的元素。所以我的新列表将如下所示:

[('img-1','iii'), ('img-2','jjj')] 

谢谢!

回答

18

方式一:

>>> 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')] 

首先是所谓的清单理解。有关相关技术,请参阅F.C.'s answer。基本语法是[{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 
+1

这太好了。这两种技术有没有名字?我想更多地阅读这些方法。谢谢。 – sidewinder

+1

@Awais,请参阅我的编辑以获取更详细的解释。 – senderle

+1

第一个是[list comprehension](http://docs.python.org/tutorial/datastructures.html#list-comprehensions)第二个是[filter](http://docs.python.org/library/functions .html#filter)和[lambda表达式](http://docs.python.org/reference/expressions.html#lambda) – agf

6

也许这样的事情?

l2 = [item for item in l1 if item[0].startswith('img')] 
+0

这是一件好事。谢谢! – sidewinder

3

只是另一种方式与generator expression(它可以使大名单差一些)

>>> l = [('text-1','xxx'), ('img-1','iii'), ('img-2','jjj'), ('text-2','xxx')] 
>>> (x for x in l if x[0].find('img') == 0) 
0: <generator object <genexpr> at 0x917a00> 
>>> gen = (x for x in l if x[0].find('img') == 0) 
>>> list(gen) 
1: [('img-1', 'iii'), ('img-2', 'jjj')] 
1
tuple_filter = lambda t, i, w: filter(lambda a: a[i].startswith(w), t) 
newtuple = tuple_filter(thetuple, 0, 'img') 
相关问题