python多进程共享对象_python中的多处理 – 在多个进程之间共享大对象(例如大熊猫数据帧)...

Value的第一个参数是typecode_or_type.这被定义为:

typecode_or_type determines the type of the returned object: it is

either a ctypes type or a one character typecode of the kind used by

the array module. *args is passed on to the constructor for the type.

强调我的所以,你根本不能把一个熊猫数据框放在一个值,它必须是a ctypes type.

您可以使用multiprocessing.Manager将您的单例数据帧实例提供给所有进程.有几种不同的方式在同一个地方结束 – 可能最简单的方法是将数据框放在经理的命名空间中.

from multiprocessing import Manager

mgr = Manager()

ns = mgr.Namespace()

ns.df = my_dataframe

# now just give your processes access to ns, i.e. most simply

# p = Process(target=worker, args=(ns, work_unit))

现在,您的数据框实例可以被任何通过对Manager的引用的进程访问.或者只是传递对命名空间的引用,它更干净.

我没有/不会覆盖的一件事是事件和信号 – 如果您的进程需要等待其他人完成执行,则需要在Here is a page中添加一些事件示例,其中还包含一些更详细的信息如何使用经理的命名空间.

(请注意,没有一个解决多处理是否会产生实际的性能优势,这只是给您工具来探索这个问题)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值