根据每个列表第一个元素从列表列表中删除项目

And*_*ewK 5 python list python-3.x

鉴于:

a = [[1,2],[3,4],[5,6],[7,8]]
b = 3
Run Code Online (Sandbox Code Playgroud)

我想删除一个项目a,b因为它是第一个项目.所以在这种情况下我们会删除[3,4]给:

a = [[1,2],[5,6],[7,8]]
Run Code Online (Sandbox Code Playgroud)

我目前的代码是:

if b in [i[0] for i in a]:
    pos = [i[0] for i in a].index(b)
       del a[pos]
Run Code Online (Sandbox Code Playgroud)

这有效,但很慢.有什么更好的方法呢?

编辑:我之前没有测试过性能,所以我可能做错了但是我得到了这个:

def fun1():
    lst = [[x, 2*x] for x in range(1000000)]
    lst = [x for x in lst if x[0] != 500]
    return lst

def fun2():
    lst = [[x, 2*x] for x in range(1000000)]
    for i in reversed(range(len(lst))):
        if lst[i][0] == 500:
            del lst[i]
    return lst

cProfile.runctx('fun1()', None, locals())
        6 function calls in 0.460 seconds

cProfile.runctx('fun2()', None, locals())
        6 function calls in 0.502 seconds
Run Code Online (Sandbox Code Playgroud)

cs9*_*s95 10

反向删除a,就地修改:

for i in reversed(range(len(a))):
    if a[i][0] == 3:
        del a[i]
Run Code Online (Sandbox Code Playgroud)

就地修改意味着这更有效,因为它不会创建新列表(如列表理解那样).


由于OP请求一个高性能的解决方案,这里是timeit两个最高投票答案之间的比较.

建立 -

a = np.random.choice(4, (100000, 2)).tolist()

print(a[:5])
[[2, 1], [2, 2], [3, 2], [3, 3], [3, 1]]
Run Code Online (Sandbox Code Playgroud)

列表理解 -

%timeit [x for x in a if x[0] != b]
11.1 ms ± 685 µs per loop (mean ± std. dev. of 7 runs, 100 loops each)
Run Code Online (Sandbox Code Playgroud)

反向删除 -

%%timeit
for i in reversed(range(len(a))):
    if a[i][0] == 3:
        del a[i]

10.1 ms ± 146 µs per loop (mean ± std. dev. of 7 runs, 1 loop each)
Run Code Online (Sandbox Code Playgroud)

它们非常接近,但反向删除在性能上有1UP,因为它不必在内存中生成新列表,因为列表理解会如此.

  • @KeyurPotdar哈,干杯队友,投票归来. (2认同)

Key*_*dar 7

您可以使用列表理解:

>>> a = [[1,2],[3,4],[5,6],[7,8]]
>>> b = 3
>>> a = [x for x in a if x[0] != b]
>>> a
[[1, 2], [5, 6], [7, 8]]
Run Code Online (Sandbox Code Playgroud)