说我有一个元组列表。我想在保留原始顺序的同时将所有元组的第二个元素放在自己的列表中。有没有快速而肮脏的方法来做到这一点?
排序之前的例子。
[(0,'apple'),
(1,'pineapple'),
(11,'cherry'),
(12,'banana'),
(13,'mango'),
(14,'boot'),
(15,'mangosteen')]
排序后
['apple',
'pineapple',
'cherry',
'banana',
'mango',
'boot',
'mangosteen']
答案 0 :(得分:3)
您基本上只需要在列表中映射获取每个元组的索引1处的元素的操作并生成新列表。
假设:
>>> LoT
[(0, 'apple'), (1, 'pineapple'), (11, 'cherry'), (12, 'banana'), (13, 'mango'), (14, 'boot'), (15, 'mangosteen')]
您可以使用列表推导并访问每个元组的感兴趣元素:
>>> [t[1] for t in LoT]
['apple', 'pineapple', 'cherry', 'banana', 'mango', 'boot', 'mangosteen']
您可以使用元组解包:
>>> [b for _,b in LoT]
['apple', 'pineapple', 'cherry', 'banana', 'mango', 'boot', 'mangosteen']
如果元组长度不超过2个元素,则会失败。
或者,您可以使用zip
:
>>> list(zip(*LoT))[1]
('apple', 'pineapple', 'cherry', 'banana', 'mango', 'boot', 'mangosteen')
您可以itemgetter使用map:
>>> list(map(itemgetter(1),LoT))
['apple', 'pineapple', 'cherry', 'banana', 'mango', 'boot', 'mangosteen']
使用Python3,您需要在list
周围使用zip
下标第一个元素或在map
周围显示它。结合Python 3中的循环或其他流程控制,您可能不需要它。
第一个[t[1] for t in LoT]
是最惯用的,最后一个,map(itemgetter(1),LoT)
可能是最快的。
答案 1 :(得分:2)
Tuple拆包作为替代方案。
[b for a,b in lst]