zip和imap的结合

#a = [1, 2, 3]
#b = [4, 5, 6]
#z = zip(a, b)
#print(z)
#print(list(z))

#print('a is {} , b is {}'.format(a, b))

from multiprocessing.pool import ThreadPool, Pool
import sys
from _typeshed import Self, _T_co
from typing import Any, Callable, Generic, Iterable, Iterator, SupportsComplex, SupportsFloat, SupportsInt, TypeVar, overload
from typing_extensions import Literal, SupportsIndex

_T = TypeVar("_T")


def func2(param) -> _T:
    ...


def func(args) -> list:
    print(args)
    xx, yy = args

    return [xx, yy]


if __name__ == '__main__':

    a = [1, 2, 3]
    b = [4, 5, 6]
    z = zip(a, b)
    for i in z:
        print(i)

    with Pool(3) as pool:
        iter = pool.imap(func, zip([1, 2, 3], [4, 5, 6]))

        for x, y in iter:
            print('x is {}, y is {}'.format(x, y))

运行结果如下:

(1)zip在python3.x中是返回一个对象,zip函数中的参数均要为可迭代的对象(如列表)

(2)zip本身是itertools这个标准库中的,zip返回值也即本身是一个可迭代的对象,即迭代器

(3)可以使用for x in zipped这种循环方法逐个迭代出

(4)我一开始一直有个疑惑,明明在func函数传递给args的是一个元组,例如(1, 4)。后面我才明白实际zip是迭代器,每次迭代一个给函数func去处理的,因此上面采用那种运行结果!

(5)imap返回的也是一个迭代器

(6)最后注意这种def funtion(args) -> _T:...

这种相当于只是声明。...的作用相当于pass,_T相当于一个模板类over

 类似上图中,带有@overload表示可以被重写的,这里相当于只进行了声明,可以在其他地方进行重写覆盖

参考:

Python3 zip() 函数 | 菜鸟教程

关于多处理:在Python中将多个参数传递给pool.map()函数 | 码农家园 (codenong.com)

 Python 3 中的 Itertools - 知乎 (zhihu.com)

进程池Pool的imap方法解析 - 简书 (jianshu.com)

pool.imap_梦否的博客-CSDN博客_pool.imap

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

曙光_deeplove

你的鼓励是我努力的最大源泉

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

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

打赏作者

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

抵扣说明:

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

余额充值