1

我有一个元组列表。我想删除列表中元组中第 2 和第 3 项为bananasand的所有项1。for 循环不起作用,因为它在遍历列表时会从列表中删除项目。不知道该怎么做?

my_table = [('apples', 'bananas', 1), ('pears', 'bananas', 1), ('grapes', 'apple', 2), ('apples,' 'pears', 2), ('apples', 'bananas', 2), ('grapes', 'bananas', 2)]

>>> printTable(my_table)
('apples', 'bananas', 1)
('pears', 'bananas', 1)
('grapes', 'apple', 2)
('apples,pears', 2)
('apples', 'bananas', 2)
('grapes', 'bananas', 2)

>>> for item, row in enumerate(my_table):
    if row[1] == 'bananas' and row[2] == 1:
        print item, row

0 ('pears', 'bananas', 1)
5 ('apples', 'bananas', 1)
6 ('grapes', 'bananas', 1)

>>> for item, row in enumerate(my_table):
    if row[1] == 'bananas' and row[2] == 1:
        my_table.remove(row)

>>> printTable(my_table)
('pears', 'bananas', 1)
('grapes', 'apple', 2)
('apples,pears', 2)
('apples', 'bananas', 2)
4

2 回答 2

7

改用列表推导:

my_table = [elem for elem in my_table if elem[1:] != ('bananas', 1)]

这将删除视为过滤作业;通过创建一个新列表来保留不应删除的所有内容。

于 2013-02-27T15:05:40.573 回答
0

你也可以这样做:

filterted_table=filter(lambda t: t[1:]!=('bananas', 1),my_table)
于 2013-02-27T15:21:01.957 回答