Python itertools 部分用法

过滤的部分用法


import itertools


def vowel(c):
    return c.lower() in 'aeiou'


name = 'Aardvark'

print(list(filter(vowel, 'Aardvark')))
# ['A', 'a', 'a']

# 与 filter 函数的作用类似,不过 predicate 的 逻辑是相反的:predicate 返回假值时产出对应 的元素
print(list(itertools.filterfalse(vowel, 'Aardvark')))
# ['r', 'd', 'v', 'r', 'k']

# 处理 it,跳过 predicate 的计算结果为真值的元 素,然后产出剩下的各个元素(不再进一步检 查)满足条件的值都会丢弃直到有元素不满足为止
print(list(itertools.dropwhile(vowel, 'Aardvark')))
# ['r', 'd', 'v', 'a', 'r', 'k']

# predicate 返回真值时产出对应的元素,然后立 即停止,不再继续检查
print(list(itertools.takewhile(vowel, 'Aardvark')))
# ['A', 'a']

# 并行处理两个可迭代的对象;如果 selector_it 中的元素是真值,产出 it 中对应的元素
print(list(itertools.compress('Aardvark', (1, 0, 1, 1, 0, 1))))
# ['A', 'r', 'd', 'a']

# 产出 it 的切片,作用类似于 s[:stop] 或 s[start:stop:step],不过 it 可以是任何可迭代 的对象,而且这个函数实现的是惰性操作
print(list(itertools.islice('Aardvark', 4)))
# ['A', 'a', 'r', 'd']

用于映射的生成器 accumulate


import itertools

import operator

sample = [5, 4, 2, 8, 7, 6, 3, 0, 9, 1]

# 计算总和
print(list(itertools.accumulate(sample)))
# [5, 9, 11, 19, 26, 32, 35, 35, 44, 45]

# 计算最小值
print(list(itertools.accumulate(sample, min)))
# [5, 4, 2, 2, 2, 2, 2, 0, 0, 0]

# 计算最大值
print(list(itertools.accumulate(sample, max)))
# [5, 5, 5, 8, 8, 8, 8, 8, 9, 9]

# 计算乘积
print(list(itertools.accumulate(sample, operator.mul)))
# [5, 20, 40, 320, 2240, 13440, 40320, 0, 0, 0]

# 计算阶乘
print(list(itertools.accumulate(range(1, 11), operator.mul)))
# [1, 2, 6, 24, 120, 720, 5040, 40320, 362880, 3628800]


# 从1 开始,为单词中的字母编号
print(list(enumerate('albatroz', 1)))
# [(1, 'a'), (2, 'l'), (3, 'b'), (4, 'a'), (5, 't'), (6, 'r'), (7, 'o'), (8, 'z')]

# 从 0 到 10,计算各个整数的平方
print(list(map(operator.mul, range(11), range(11))))
# [0, 1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

# 计算两个可迭代对象中对应位置上的两个元素之积,元素最少的那 个可迭代对象到头后就停止
print(list(map(operator.mul, range(11), [2, 4, 8])))
# [0, 4, 16]

# 作用等同于内置的 zip 函数
print(list(map(lambda a, b: (a, b), range(11), [2, 4, 8])))
# [(0, 2), (1, 4), (2, 8)]

# 从 1 开始,根据字母所在的位置,把字母重复相应的次数
print(list(itertools.starmap(operator.mul, enumerate('albatroz', 1))))
# ['a', 'll', 'bbb', 'aaaa', 'ttttt', 'rrrrrr', 'ooooooo', 'zzzzzzzz']

# [5, 4, 2, 8, 7, 6, 3, 0, 9, 1]
print(list(itertools.accumulate(sample)))
# [5, 9, 11, 19, 26, 32, 35, 35, 44, 45]
# 计算平均值
print(list(itertools.starmap(lambda a, b: b / a, enumerate(itertools.accumulate(sample), 1))))
# [5.0, 4.5, 3.6666666666666665, 4.75, 5.2, 5.333333333333333, 5.0, 4.375, 4.888888888888889, 4.5]

用于合并的生成器函数 chain


import itertools

import operator

# 调用 chain 函数时通常传入两个或更多个可迭代对象。 用于连接多个列表或者迭代器。
print(list(itertools.chain('ABC', range(2))))
# ['A', 'B', 'C', 0, 1]

# 如果只传入一个可迭代的对象,那么 chain 函数没什么用
print(list(itertools.chain(enumerate('ABC'))))
# [(0, 'A'), (1, 'B'), (2, 'C')]

# 但是 chain.from_iterable 函数从可迭代的对象中获取每个元素, 然后按顺序把元素连接起来,前提是各个元素本身也是可迭代的对象
print(list(itertools.chain.from_iterable(enumerate('ABC'))))
# [0, 'A', 1, 'B', 2, 'C']

# zip 常用于把两个可迭代的对象合并成一系列由两个元素组成的元组
print(list(zip('ABC', range(5))))
# [('A', 0), ('B', 1), ('C', 2)]

# zip 可以并行处理任意数量个可迭代的对象,不过只要有一个可迭代 的对象到头了,生成器就停止
print(list(zip('ABC', range(5), [10, 20, 30, 40])))
# [('A', 0, 10), ('B', 1, 20), ('C', 2, 30)]

# itertools.zip_longest 函数的作用与 zip 类似,不过输入的所有 可迭代对象都会处理到头,如果需要会填充 None
print(list(itertools.zip_longest('ABC', range(5))))
# [('A', 0), ('B', 1), ('C', 2), (None, 3), (None, 4)]

# fillvalue 关键字参数用于指定填充的值
print(list(itertools.zip_longest('ABC', range(5), fillvalue='?')))
# [('A', 0), ('B', 1), ('C', 2), ('?', 3), ('?', 4)]

product 生成器函数

import itertools

# 三个字符的字符串与两个整数的值域得到的笛卡儿积是六个元组 (因为 3 * 2 等于 6)
print(list(itertools.product('ABC', range(2))))
# [('A', 0), ('A', 1), ('B', 0), ('B', 1), ('C', 0), ('C', 1)]


suits = 'spades hearts diamonds clubs'.split()

# 两张牌('AK')与四种花色得到的笛卡儿积是八个元组
print(list(itertools.product('AK', suits)))
# [('A', 'spades'), ('A', 'hearts'), ('A', 'diamonds'), ('A', 'clubs'), ('K', 'spades'), ('K', 'hearts'), ('K', 'diamonds'), ('K', 'clubs')]

# 如果传入一个可迭代的对象,product 函数产出的是一系列只有一 个元素的元组,不是特别有用
print(list(itertools.product('ABC')))
# [('A',), ('B',), ('C',)

# repeat=N 关键字参数告诉 product 函数重复 N 次处理输入的各个 可迭代对象
print(list(itertools.product('ABC', repeat=2)))
# [('A', 'A'), ('A', 'B'), ('A', 'C'), ('B', 'A'), ('B', 'B'), ('B', 'C'), ('C', 'A'), ('C', 'B'), ('C', 'C')]

print(list(itertools.product(range(2), repeat=3)))
# [(0, 0, 0), (0, 0, 1), (0, 1, 0), (0, 1, 1), (1, 0, 0), (1, 0, 1), (1, 1, 0), (1, 1, 1)]

rows = itertools.product('AB', range(2), repeat=2)
for row in rows: print(row)
# ('A', 0, 'A', 0)
# ('A', 0, 'A', 1)
# ('A', 0, 'B', 0)
# ('A', 0, 'B', 1)
# ('A', 1, 'A', 0)
# ('A', 1, 'A', 1)
# ('A', 1, 'B', 0)
# ('A', 1, 'B', 1)
# ('B', 0, 'A', 0)
# ('B', 0, 'A', 1)
# ('B', 0, 'B', 0)
# ('B', 0, 'B', 1)
# ('B', 1, 'A', 0)
# ('B', 1, 'A', 1)
# ('B', 1, 'B', 0)
# ('B', 1, 'B', 1)

count、repeat、cycle 用法

import itertools

import operator

# 使用 count 函数构建 ct 生成器
ct = itertools.count()

# 获取 ct 中的第一个元素
print(next(ct))
# 0

# 不能使用 ct 构建列表,因为 ct 是无穷的,所以我获取接下来的 3 个元素。
print(next(ct), next(ct), next(ct))
# 1 2 3

# 如果使用 islice 或 takewhile 函数做了限制,可以从 count 生成 器中构建列表
print(list(itertools.islice(itertools.count(1, .3), 3)))
# [1, 1.3, 1.6]

# 使用 'ABC' 构建一个 cycle 生成器,然后获取第一个元素 ——'A'
cy = itertools.cycle('ABC')
print(next(cy))
# A

# 只有受到 islice 函数的限制,才能构建列表;这里获取接下来的 7 个元素
print(list(itertools.islice(cy, 7)))
# ['B', 'C', 'A', 'B', 'C', 'A', 'B']

#  构建一个 repeat 生成器,始终产出数字 7
rp = itertools.repeat(7)
print(next(rp), next(rp))
# 7 7

# 传入 times 参数可以限制 repeat 生成器生成的元素数量:这里会 生成 4 次数字 8
print(itertools.repeat(8, 4))
# repeat(8, 4)

# repeat 函数的常见用途:为 map 函数提供固定参数,这里提供的是 乘数 5。
print(list(map(operator.mul, range(11), itertools.repeat(5))))
# [0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50]

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值