zoukankan      html  css  js  c++  java
  • Python高级编程-itertoos模块

    Python的内建模块itertools提供了非常有用的用于操作迭代对象的函数。

    首先我们看看itertools模块提供的几个“无限”迭代器,

    1 import itertools
    2 
    3 naturals = itertools.count(1)
    4 for i in naturals:  # Count(self, start, step)
    5     print(i)

    因为count()会创建一个无限的迭代器,所以上述代码会打印出自然数序列,根本停不下来,只能按Ctrl+C退出

    islice() 正好适用于在迭代器和生成器上做切片操作。

    1 for i in itertools.islice(naturals, 1, 10):
    2     print(i)

    程序输出的是2到10,注意islice()函数输出不包含start,包含stop

    cycle()会把传入的一个序列无限重复下去:

    1 for i in itertools.cycle([1, 2, 3]):
    2     print(i)

    同样停不下来

    repeat()负责把一个元素无限重复下去,不过如果提供第二个参数就可以限定重复次数

    1 for c in itertools.repeat('A', 3):
    2     print(c)

    程序输出:

    1 A
    2 A
    3 A

    无限序列只有在for迭代时才会无限地迭代下去,如果只是创建了一个迭代对象,它不会事先把无限个元素生成出来,事实上也不可能在内存中创建无限多个元素。

    无限序列虽然可以无限迭代下去,但是通常我们会通过takewhile()等函数根据条件判断来截取出一个有限的序列:

    1 naturals = itertools.count(1)
    2 for i in itertools.takewhile(lambda x: x < 10, naturals):
    3     print(i)

    程序输出1到9的自然数。

    与takewhile()相对应的有dropwhile()

    1 for i in itertools.dropwhile(lambda x: x >= 10, naturals):
    2     print(i)

    chain()可以把一组迭代对象串联起来,形成一个更大的迭代器:

    1 for i in itertools.chain([1, 2, 3], [4, 5, 6]):
    2     print(i)

     itertools.chain() 接受一个或多个可迭代对象最为输入参数。然后创建一个迭代器,依次连续的返回每个可迭代对象中的元素。这种方式要比先将序列合并再迭代要高效的多。比如:

    1 # Inefficent
    2 for x in a + b:
    3 ...
    4 # Better
    5 for x in chain(

    groupby()把迭代器中相邻的重复元素挑出来放在一起:

    1 for key, group in itertools.groupby('AAABBBCCCAAA'):
    2     print(key, list(group))

    实际上挑选规则是通过函数完成的,只要作用于函数的两个元素返回的值相等,这两个元素就被认为是在一组的,而函数返回值作为组的key。如果我们要忽略大小写分组,就可以让元素'A''a'都返回相同的key:

    1 for key, group in itertools.groupby('AaaBbbCCc', lambda c: c.upper()):
    2     print(key, list(group))

    itertools模块提供的全部是处理迭代功能的函数,它们的返回值不是list,而是Iterator,只有用for循环迭代的时候才真正计算

  • 相关阅读:
    hdu 4614 线段树 二分
    cf 1066d 思维 二分
    lca 最大生成树 逆向思维 2018 徐州赛区网络预赛j
    rmq学习
    hdu 5692 dfs序 线段树
    dfs序介绍
    poj 3321 dfs序 树状数组 前向星
    cf 1060d 思维贪心
    【PAT甲级】1126 Eulerian Path (25分)
    【PAT甲级】1125 Chain the Ropes (25分)
  • 原文地址:https://www.cnblogs.com/z-joshua/p/6547383.html
Copyright © 2011-2022 走看看