假设我有这样一个元组:查找在一个元组元素,并筛选他们
[('text-1','xxx'), ('img-1','iii'), ('img-2','jjj'), ('text-2','xxx')]
我想筛选出的名单,并产生一个新的有与“IMG”开头的元素。所以我的新列表将如下所示:
[('img-1','iii'), ('img-2','jjj')]
谢谢!
假设我有这样一个元组:查找在一个元组元素,并筛选他们
[('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')]
首先是所谓的清单理解。有关相关技术,请参阅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
只是另一种方式与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')]
tuple_filter = lambda t, i, w: filter(lambda a: a[i].startswith(w), t)
newtuple = tuple_filter(thetuple, 0, 'img')
这太好了。这两种技术有没有名字?我想更多地阅读这些方法。谢谢。 – sidewinder
@Awais,请参阅我的编辑以获取更详细的解释。 – senderle
第一个是[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