为什么我不能迭代(多处理)管理器列表?

时间:2015-11-15 14:29:31

标签: python python-multiprocessing

我有一个由经理列表组成的数组,如:

[<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?

我怎么能在oneliner中做到这一点?

1 个答案:

答案 0 :(得分:1)

解释您的代码无效的原因。 iter()获取一个可迭代对象并返回一个interator。 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]