乐趣区

关于python:Python代码阅读第29篇使用初始化种子和迭代函数生成列表

Python 代码浏览合集介绍:为什么不举荐 Python 初学者间接看我的项目源码

本篇浏览的代码实现应用一个初始化种子和迭代函数,通过嵌套函数对初始化种子进行迭代,最终生成一个列表。

本篇浏览的代码片段来自于 30-seconds-of-python。

unfold

def unfold(fn, seed):
  def fn_generator(val):
    while True: 
      val = fn(val[1])
      if val == False: break
      yield val[0]
  return [i for i in fn_generator([None, seed])]

# EXAMPLES
f = lambda n: False if n > 50 else [-n, n + 10]
unfold(f, 10) # [-10, -20, -30, -40, -50]

unfold函数接管一个迭代函数和一个初始化种子,生成一个列表。迭代函数 fn 承受一个参数 seed,并且必须总是返回一个有两个元素的列表[value,nextSeed],或者返回False 来终止生成器函数。unfold函数外部定义生成器 fn_generator。该生成器应用while 循环调用迭代器函数并产生值,直到它返回 False。最初应用列表推导式返回生成器函数产生的列表。

生成器 是一个用于创立迭代器的简略而弱小的工具。它的写法相似于规范的函数,但当它们要返回数据时会应用 yield 语句。每次在生成器上调用 next() 时,它会从上次来到的地位复原执行(它会记住上次执行语句时的所有数据值)。

fn_generator是一个生成器,在其中 while 语句的最初,应用 yield 返回以后 while 循环中 val[0] 的值。下一次调用的时候,会持续下一个循环,持续返回下一个循环中 val[0] 的值,直到迭代函数 fn 返回 false 完结 while 循环。

unfold 函数的 return 语句中,应用列表推导式一直调用 fn_generator 生成器,直到生成器退出循环,造成一个列表并返回。

退出移动版