itertools模块

2021-02-24  本文已影响0人  butters001

Functional tools for creating and using iterators. 即用于创建和使用迭代器的函数工具。

1. itertools.chain(*iterable)

将多个序列作为一个单独的序列返回。

In [33]: import itertools

In [34]: for each in itertools.chain('i', 'love', 'python'):
    ...:     print(each)
    ...: 
i
l
o
v
e
p
y
t
h
o
n

2. itertools.combinations(iterable, r)

返回指定长度的”组合”。

In [35]: for each in itertools.combinations('abc', 2):
    ...:     print(each)
    ...: 
('a', 'b')
('a', 'c')
('b', 'c')

可以看出,这个是按原字符串顺序组成的组合。

3. itertools.combinations_with_replacement(iterable, r)

返回指定长度的“组合”,组合内元素可重复

In [37]: for each in itertools.combinations_with_replacement('abc', 2):
    ...:     print(each)
    ...: 
('a', 'a')
('a', 'b')
('a', 'c')
('b', 'b')
('b', 'c')
('c', 'c')

4. itertools.product(*iterable[,repeat])

返回指定长度的所有组合,可理解为笛卡尔乘积

In [39]: for each in itertools.product('abc', repeat=2):
    ...:     print(each)
    ...: 
('a', 'a')
('a', 'b')
('a', 'c')
('b', 'a')
('b', 'b')
('b', 'c')
('c', 'a')
('c', 'b')
('c', 'c')

5. itertools.premutations(iterable[,r])

返回长度为r的排列

In [41]: for each in itertools.permutations('abc', 2):
    ...:     print(each)
    ...: 
    ...: 
('a', 'b')
('a', 'c')
('b', 'a')
('b', 'c')
('c', 'a')
('c', 'b')

6. itertools.compress(data,selector)

返回selector为True的data对应元素

In [42]: for each in itertools.compress('abcd', [1, 0, 1, 0]):
    ...:     print(each)
    ...: 
a
c

7. itertools.count(start=0,step=1)

返回以start开始,step递增的序列,无限递增

In [44]: for each in itertools.count(start=0, step=2):
    ...:     if each > 20:
    ...:         break
    ...:     print(each)
    ...: 
    ...: 
0
2
4
6
8
10
12
14
16
18
20

8. itertools.cycle(iterable)

将迭代器进行无限迭代

In [45]: for each in itertools.cycle('ab'):
    ...:     print(each)
    ...: 
a
b
a
b
a
b
a
b
.
.
.

9. itertools.dropwhile(predicate, iterable)

drop掉第一个predicate为False之前的数据

In [46]: for each in itertools.dropwhile(lambda x: x<5, [2,1,6,8,2,1]):
    ...:     print(each)
    ...: 
6
8
2
1

第一个False是6,drop之前的数据,剩下的就是6, 8, 2, 1
这个功能可以用在 读取文件时,drop掉文件头部的注释。

with open('xxx.txt') as f:
...     for line in dropwhile(lambda line: line.startswith('#'), f):
...         print(line, end='')

10. itertools.groupby(iterable[,key])

返回一组(key,itera),key为iterable的值,itera为等于key的所有项

In [48]: for key, value in itertools.groupby('aabbbcacc'):
    ...:     print(key, list(value))
    ...: 
a ['a', 'a']
b ['b', 'b', 'b']
c ['c']
a ['a']
c ['c', 'c']

11. itertools.ifilter(predicate, iterable)

创建一个迭代器,只返回 iterable 中 predicate 为 False 的元素。如果 predicate 是 None,返回真值测试为false的元素。

In [52]: for value in itertools.filterfalse(lambda x: x % 2, range(10)):
    ...:     print(value)
    ...: 
0
2
4
6
8

12. itertools.islice(iterable, start,stop[,step])

相当于迭代器方式的切片操作

In [53]: for value in itertools.islice('abcdefg', 1, 4, 2):
    ...:     print(value)
    ...: 
b
d

13. itertools.repeat(object,[,times])

不停的返回object对象,如果指定了times,则返回times次

In [54]: for value in itertools.repeat('a', 2):
    ...:     print(value)
    ...: 
a
a

14. itertools.starmap(function,iterable)

返回function(iter)的值,iter为iterable的元素

In [55]: for value in itertools.starmap(lambda x, y: x * y, [(1, 2), (3, 4)]):
    ...:     print(value)
    ...: 
2
12
In [56]: for value in itertools.starmap(pow, [(2,5), (3,2), (10,3)]):
    ...:     print(value)
    ...: 
    ...: 
32
9
1000

15. itertools.takewhile(predicate,iterable)

如果predicate为真,则返回iterable元素,如果为假则不再返回,break.

In [57]: for value in itertools.takewhile(lambda x: x < 5, [1, 3, 5, 6]):
    ...:     print(value)
    ...: 
1
3
上一篇下一篇

猜你喜欢

热点阅读