繁体   English   中英

从两个同步列表中删除相同位置(索引)的项目?

[英]delete items at the same position (index) from two synchronized lists?

我有两个清单:

l1 = ['#', '1', '#', '!']
l2 = ['S', 'T', 'K', 'M']

如果l1中有一个“#”,我想将其删除,然后删除l2中相同位置的所有内容。 这是我尝试过的(除其他事项外):

for i in range(len(li[j])):
    for k in range(len(l2[n])):
        if j == "#":
            li.remove([j][i])
            l2.remove([n][k])

但是它抱怨j没有定义。 我希望结果看起来像这样:

l1 = ['1', '!']
l2 = ['T', 'M']

我将不胜感激!

>>> l1 = ['#', '1', '#', '!']
>>> l2 = ['S', 'T', 'K', 'M']

>>> l1,l2 = zip(*((x,y) for x,y in zip(l1,l2) if x!='#'))
>>> l1
('1', '!')
>>> l2
('T', 'M')  

使用filter

>>> l1,l2 = zip(*filter(lambda x: '#' not in x,zip(l1,l2)))
>>> l1
('1', '!')
>>> l2
('T', 'M')

使用itertools

>>> from itertools import compress
>>> l1,l2 = zip(*compress(zip(l1,l2),(x!='#' for x in l1)))
>>> l1
('1', '!')
>>> l2
('T', 'M')

这是一个简单易懂的方法:

a = ["#", "1", "#", "2", "3", "#"]
b = ["a", "b", "c", "d", "e", "f"]

a,b = zip(*[[a[i], b[i]] for i in range(len(a)) if a[i]!="#"])
print a
print b

我个人认为,与@jamylak提出的方法相比,它更容易理解并且更有效(阅读:“更快”)。

输出:

>>> 
('1', '2', '3')
('b', 'd', 'e')

由于您总是在两个列表中访问相同的索引,因此一个循环就足够了,但是,当列表的长度不相同时,请务必小心。

此外,在遍历列表时将其从列表中删除很容易出错,以下解决方案将所有索引存储在删除列表中,并在第二步从两个列表中删除该索引:

l1 = ['#', '1', '#', '!']    
l2 = ['S', 'T', 'K', 'M']
remove = []
for i in range(len(l1) - 1):
    if l1[i] == '#':
        remove.insert(0, i)

for i in remove:
    l1.pop(i)
    l2.pop(i)

for i in l1:
    print i
for i in l2:
    print i

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM