python多进程实现图片处理,进程池的大坑!

python多进程实现图片处理,进程池的大坑!

最近做大批量图片数据处理的时候,cpu占用一直很低,所以想用python多进程实现大量图片处理的加速。
但参考了很多很多博客,就是会有各种bug:跳过函数,函数不执行;只有主进程在运行,子进程都sleep等等。。。一一解决之后仍然跑不通,一行一行debug,找了n个小时终于发现了这个坑。

我们都知道python多进程是不共享数据的!

所以如果是用单写config的文件的,要记得在多进程传参的时候,额外把config文件的数据也传进去!

其实是知道这个点的,但之前就是没注意到这个问题,而且你只要之前定义过了变量在多进程的work_func()中也不会报错还能连接到那个数据,所以这个简单的坑困扰了很久。。

顺带一提,如果有device等等配置也需要传入哦~~

上代码:

import yaml
import os
import multiprocessing

# 图像处理
def process_image(img_path, config):
'''
图像处理操作
'''
if __name__=='__main__':

    with open('./config.yaml', 'r', encoding='utf8') as fin:
        config = yaml.safe_load(fin)

    if not os.path.exists(config['data']['dst_label_path']):
        os.makedirs(config['data']['dst_label_path'])
    if not os.path.exists(config['data']['dst_image_path']):
        os.makedirs(config['data']['dst_image_path'])

    image_list = os.listdir(config['data']['src_image_path'])
    image_list = [os.path.join(config['data']['src_image_path'], fname) for fname in image_list]

    device = 'cuda' if torch.cuda.is_available() else 'cpu'
    
    net = MagicPoint(config['model'], input_channel=1, grid_size=8, device=device)
    net.to(device).eval()


    lock = multiprocessing.Lock()
    # 创建进程池
    pool = multiprocessing.Pool(processes=4)

    for idx, fpath in tqdm(enumerate(image_list)):

        # 多进程执行
        pool.apply(process_image, args=(img_path, config))
        # pool.apply_async(process_image(idx, fpath))

    pool.close()
    pool.join()

    print('Done')

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Why_so?

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值