在元组中查找元素并对其进行过滤

发布于 2021-01-29 19:06:49

假设我有一个类似的元组:

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

我想过滤出列表并生成一个以’img’开头的元素的新列表。因此,我的新列表将如下所示:

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

谢谢!

关注者
0
被浏览
51
1 个回答
  • 面试哥
    面试哥 2021-01-29
    为面试而生,有面试问题,就找面试哥。

    单程:

    >>> 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
    


知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看