为什么无法迭代(多进程)管理器列表?

5

我有一个由管理人员列表组成的数组,例如:

[<ListProxy object, typeid 'list' at 0x177d350>, <ListProxy object, typeid 'list' at 0x177d390>, ...]

尝试将其转换为一个纯列表。我的考虑如下:

y=[]
for i in my_manager_list_content:
    for j in i:
        y.append(float(j))
print y #This works

print [next(iter(i[:]))  for i in my_manager_list_content] #Why doesn't this work?

我该如何用一行代码实现这个功能?

1
[float(i) for j in my_manager_list_content for i in j]的翻译是什么? - Remi Guan
谢谢。这就是解决方案! - Caniko
1个回答

2

为什么你的代码不起作用的解释。 iter() 接受一个可迭代对象并返回一个迭代器。 next() 取出迭代器并返回下一个元素。在你的代码中,当你从 my_manager_list_content 中取出一个元素时,你只会得到第一个元素,并使用 next 移动到 my_manager_list_content 的第二个元素。以下代码可以说明这一点:(对 @Kevin Guan 解决方案的扩展)

from multiprocessing import Process, Manager

def f(ll, l):
    for ii in range(3):
        ll.append(l)

if __name__ == '__main__':
    with Manager() as manager:
        ll = manager.list()
        l = manager.list(range(3))
        p = Process(target=f, args=(ll, l))
        p.start()
        p.join()

        print([float(ii) for jj in ll for ii in jj])
        print([next(iter(ii)) for ii in ll])

我理解了

[0.0, 1.0, 2.0, 0.0, 1.0, 2.0, 0.0, 1.0, 2.0]
[0, 0, 0]

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接