os.walk
这个函数在遍历目录树的过程中产出文件名,因此递归搜索文件系统像for 循环那样简单。
用于过滤的生成器函数
模块 | 函数 | 说明 |
itertools |
compress(it, |
并行处理两个可迭代的对象;如果 selector_it 中的元素是真值,产出 it 中对应的元素 |
itertools |
dropwhile(predicate, |
处理 it,跳过 predicate 的计算结果为真值的元 |
filter(predicate, it) |
把 it 中的各个元素传给 predicate,如果 |
|
itertools |
filterfalse(predicate, |
与 filter 函数的作用类似,不过 predicate 的 |
itertools |
islice(it, stop) 或 |
产出 it 的切片,作用类似于 s[:stop] 或 |
itertools |
takewhile(predicate, |
predicate 返回真值时产出对应的元素,然后立 |
表14-2:用于映射的生成器函数
模块 | 函数 | 说明 |
itertools |
accumulate(it, |
产出累积的总和;如果提供了 func,那么把前两个 |
enumerate(iterable, |
产出由两个元素组成的元组,结构是 (index, |
|
map(func, it1, |
把 it 中的各个元素传给func,产出结果;如果传入 |
|
itertools | starmap(func, it) |
把 it 中的各个元素传给 func,产出结果;输入的 |
表14-3:合并多个可迭代对象的生成器函数
模块 | 函数 | 说明 |
itertools | chain(it1, ..., itN) |
先产出 it1 中的所有元素,然后产出 it2 中的 |
itertools | chain.from_iterable(it) |
产出 it 生成的各个可迭代对象中的元素,一个 |
itertools |
product(it1, ..., itN, |
计算笛卡儿积:从输入的各个可迭代对象中获 |
zip(it1, ..., itN) |
并行从输入的各个可迭代对象中获取元素,产 |
|
itertools |
zip_longest(it1, ..., |
并行从输入的各个可迭代对象中获取元素,产 |
表14-4:把输入的各个元素扩展成多个输出元素的生成器函数
模块 | 函数 | 说明 |
itertools | combinations(it, out_len) |
把 it 产出的 out_len 个元素组合在 |
itertools |
combinations_with_replacement(it, |
把 it 产出的 out_len 个元素组合在 |
itertools | count(start=0, step=1) |
从 start 开始不断产出数字,按 |
itertools | cycle(it) |
从 it 中产出各个元素,存储各个元 |
itertools | permutations(it, out_len=None) |
把 out_len 个 it 产出的元素排列在 |
itertools | repeat(item, [times]) |
重复不断地产出指定的元素,除非 |
表14-5:用于重新排列元素的生成器函数
模块 | 函数 | 说明 |
itertools | groupby(it,key=None) |
产出由两个元素组成的元素,形式为 (key, |
reversed(seq) |
从后向前,倒序产出 seq 中的元素;seq 必须是序 |
|
itertools | tee(it, n=2) |
产出一个由 n 个生成器组成的元组,每个生成器 |