3

根据例如列表中该元组的第二个元素并将该元组移动到列表顶部的形式查找某个元组的最有效方法是什么:

LL=[('a','a'),('a','b'),('a','c'),('a','d')]
LL.insert(0,LL.pop(LL.index( ... )))

我想要 index() 中的一些东西,它会给我以'c'作为第二个元素的元组的位置。

有没有经典的 python 1-line 方法来做到这一点?

4

4 回答 4

2

要找到职位,您可以:

positions = [i for i, tup in enumerate(LL) if tup[1] == 'c']

您现在可以获取所需元素的索引,将其弹出并推送到列表的开头

pos = positions[0]
LL.insert(0, LL.pop(pos))

但是您也可以使用元组中的项目作为键对列表进行排序:

sorted(LL, key=lambda tup: tup[1] == 'c', reverse=True)

如果您不关心其他元素的顺序

于 2013-05-10T09:10:14.580 回答
2
>>> LL.insert(0,LL.pop([x for x, y in enumerate(LL) if y[1] == 'c'][0]))
>>> LL
[('a', 'c'), ('a', 'a'), ('a', 'b'), ('a', 'd')]
>>> 
于 2013-05-10T09:11:03.660 回答
0

2 行,但是 1 行解决方案都是低效的

>>> LL=[('a','a'),('a','b'),('a','c'),('a','d')]
>>> i = next((i for i, (x, y) in enumerate(LL) if y == 'c'), 0) # 0 default index
>>> LL[0], LL[i] = LL[i], LL[0]
>>> LL
[('a', 'c'), ('a', 'b'), ('a', 'a'), ('a', 'd')]

如果未找到索引,则此操作无效

>>> LL=[('a','a'),('a','b'),('a','c'),('a','d')]
>>> i = next((i for i, (x, y) in enumerate(LL) if y == 'e'), 0) # 0 default index
>>> LL[0], LL[i] = LL[i], LL[0]
>>> LL
[('a', 'a'), ('a', 'b'), ('a', 'c'), ('a', 'd')]
于 2013-05-10T09:19:21.007 回答
0

简洁、pythonic、“fancy schmancy”解决方案的问题是代码可能不容易在其他紧密对齐的上下文中维护和/或重用。

最好只使用“样板”代码进行搜索,然后继续应用特定要求。

因此,这里有一个易于理解的搜索代码示例,当这些问题出现时,可以轻松“插入”,包括我们需要知道是否找到密钥的情况。

def searchTupleList(list_of_tuples, coord_value, coord_index):
    for i in range(0, len(list_of_tuples)):
        if list_of_tuples[i][coord_index] == coord_value:
            return i               # matching index in list
    return -1                      # not found
于 2019-03-06T16:49:41.197 回答