python_迭代器与生成器

一. 迭代器

什么是迭代器:python

  1. 提供了一个方法,能够不断获取对象里的数据。
  2. 用户不须要关心内部细节,只须要经过这个特定接口获取数据。
  3. 当没有数据时,再次调用时,会获得一个中止标记。
  4. 不能随机访问集合中的某个值 ,只能从头至尾依次访问
  5. 访问到一半时不能往回退
  6. 便于循环比较大的数据集合,节省内存
可迭代对象:
    能够经过函数 iter(对象) 生成一个迭代器的对象,都是可迭代对象
迭代器:
next(对象)  使用next 可以获取到对象的下一个值,这个对象就被称为迭代器
    next()函数的本质,就是 调用 对象的  __next__() 方法,实现了 __next__() 方法的对象,就是迭代器
生成迭代器的方法:
    iter(可迭代对象)
    经过模块 itertools

检测一个对象是不是可迭代对象:   isinstance(对象,类)函数

from  collections import Iterable
isinstance(对象,Iterable)

可迭代对象:spa

        实现了 __iter__()         方法的对象,就是可迭代对象       code

def __iter__(self):
    return self

例 需求:  使用迭代器实现斐波那契数列对象

"""
迭代一个斐波那契数列
"""
class Fibonacci(object):
    def __init__(self):      #  初始化参数
        self.__f1 = 1
        self.__f2 = 0

    def __iter__(self):
        return self

    def __next__(self):
        self.__f1, self.__f2 = self.__f2, self.__f2 +self.__f1         #  实现逻辑的方法
  
        return self.__f1


res = Fibonacci(20)   #  传入一个实参
i = 0
for v in res:
    if i <= 10:     #  遍历打印输出10次
        print(v)
        i += 1
    else:

二 . 生成器

什么事生成器:blog

利用迭代器,咱们能够不断的获取数据。在实际开发中,咱们有时候但愿数据一开始不存放在内存上,并且在遵循某种规律的状况下,用的时候再给用户.接口

生成器实际上是一种特殊的迭代器,不过这种迭代器更加优雅。它不须要再像上面的类同样写__iter__()和__next__()方法内存

列表生成器:ci

li1 = [v * 5 for v in range(10)]         #  这是列表推导式,  掉不调用都生成一个列表,耗资源资源

print(li)

li2 = (v * 5 for v in range(10))       #  这是列表生成器,调用时再加载,节约资源

print(next(li2))

print(next(li2))

print(next(li2))

函数生成器:   yield

    使用yield,yield至关与return,但不是中止函数执行,而是至关于暂停函数执行

注意: 函数生成器,是经过函数内部使用yield来实现的,一旦函数内部使用yield,函数名()调用时,函数的代码不会执行,会返回一个生成器,使用next(生成器)时,函数代码从开始执行,直到遇到yield,代码暂停执行,当再次使用next是,继续执行.(意思就是调用一次,加载一次)

例  需求: 使用函数生成器_斐波那契数列

def fib(n):   # 定义一个待传入的形参
    x, y = 0, 1
    i = 0
    while i <= n:
        x, y = y, x + y             #   斐波那契数列( 普通函数 )
        print(x)
        i += 1

fib(10)     #   传入实参,范围显示

扩展: @property的装饰器  能够让咱们的代码变得更加的简介优雅.

相关文章
相关标签/搜索