Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/305.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 在元组中查找并过滤元素_Python - Fatal编程技术网

Python 在元组中查找并过滤元素

Python 在元组中查找并过滤元素,python,Python,假设我有一个元组,如: [('text-1','xxx'), ('img-1','iii'), ('img-2','jjj'), ('text-2','xxx')] 我想过滤掉这个列表,并用以“img”开头的元素生成一个新的列表。因此,我的新列表如下所示: [('img-1','iii'), ('img-2','jjj')] 谢谢 大概是这样的吧 l2 = [item for item in l1 if item[0].startswith('img')] 单向: >>>

假设我有一个元组,如:

[('text-1','xxx'), ('img-1','iii'), ('img-2','jjj'), ('text-2','xxx')]
我想过滤掉这个列表,并用以“img”开头的元素生成一个新的列表。因此,我的新列表如下所示:

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

谢谢

大概是这样的吧

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

>>> 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')]
第一种称为列表理解。有关相关技术,请参阅。基本语法是{iterable}中{item\u var\u或{u vars}的
[{expression}如果{boolean\u expression}]
。它在语义上等同于这样的东西:

new_list = []
for {item_var_or_vars} in {iterable}:
    if {boolean_expression}:
        new_list.append({expression})
if{boolean_expression}
位是可选的,就像在for循环中一样

第二个是内置函数
filter
,它接受一个测试函数和一个iterable,并返回一个包含“通过”测试函数的每个元素的列表
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
只是另一种方式(它可能会在大型列表上产生一些差异)

>>l=[('text-1','xxx'),('img-1','iii'),('img-2','jjj'),('text-2','xxx')]
>>>(如果x[0],则表示l中的x。查找('img')==0)
0: 
>>>gen=(如果x[0],则x代表l中的x。查找('img')==0)
>>>列表(gen)
1:[('img-1','iii'),('img-2','jjj')]
带正常循环

input = [('text-1','xxx'), ('img-1','iii'), ('img-2','jjj'), ('text-2','xxx')]
inp = []
for i in input:
    if 'img' in i[0]:
        inp.append(i)
print(inp)
或者使用lambda函数

inp = list(filter(lambda x: 'img' in x[0],input))
 print(inp)
或者使用列表理解

 inp = [i for i in input if 'img' in i[0]]
 print(inp)

这太棒了。这两种技术都有名字吗?我想更多地阅读这些方法。谢谢。第一个是a,第二个是a,谢谢。这是很有见地的。
inp = list(filter(lambda x: 'img' in x[0],input))
 print(inp)
 inp = [i for i in input if 'img' in i[0]]
 print(inp)