从循环并行调用python方法

时间:2018-06-09 20:22:32

标签: python parallel-processing multiprocessing

我有一个方法1,其中循环正在运行并调用另一个方法2 但我想知道我如何并行调用方法2,因为它执行一些顺序步骤,方法2的call-1应该从方法2的call-2分离...所以这里是我的代码 方法2

def upload_image(img):
    sess = requests.Session()
    sess.verify = False
    start_upload_response = requests.post('https://awsimgproc.com/start_upload', data={"album_id36": 1}, verify=False)
    start_upload_response.raise_for_status()
    result = start_upload_response.json()
    our_upload = result['upload_id36']
    url = 'https://awsimgproc.com/uploadImage'
    files = {'file': open(img, 'rb')}
    data = {'upload_id36':our_upload}
    # This makes the post requests async
    global api_response
    api_response.append(grequests.post(url,data=data,files=files))

方法1

def image_generator():
    # Change here the location of iamge file
    image_file_location = "/home/gaurav/Pictures/sofa-3"
    extension = ".jpg"
    i=1
    img = Image.open(image_file_location + extension)

    start_time = datetime.now()

    # can change minutes as per need i.e for how much you need run 
    test suite
    end_time = start_time + timedelta(minutes=1)

    while start_time < end_time:
        # change current image and randomly roating the image
        rotated_image = img.rotate(random.randint(1,1000))
        new_image_loaction = image_file_location+str(i)+extension
        rotated_image.save(new_image_loaction)

        # upload the newly rotated image
        upload_image(new_image_loaction)

        # uncomment this line to add sleep to your method
        # time.sleep(random.randint(1,5))
        start_time = datetime.now()
        i += 1

1 个答案:

答案 0 :(得分:0)

正如您在自己的评论中所建议的那样,多处理确实是一种异步上传的有效方式。

如果您有兴趣深入研究Python中更现代的异步编程,那么您的问题就是尝试使用asyncio或其他异步事件循环实现的一个简单的用例。参见例如资源awesome-asyncio