#!/usr/bin/python
import sys

'''
迭代器是一个可以记住遍历的位置的对象。
迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束。迭代器只能往前不会后退。
迭代器有两个基本的方法:iter() 和 next()。
字符串,列表或元组对象都可用于创建迭代器
'''
list1 = [1,2,3,4,5]
it1 = iter(list1)    # 创建迭代器对象
#迭代器对象可以使用常规for语句进行遍历
for x in it1:
    print(x, end = ",")
    
#列表自己也可以使用for循环进行遍历
for x in list1:
    print(x, end = ":")

#也可以使用while循环进行遍历,使用 next() 函数
it2 = iter(list1)
'''
while True:
    try:
        print(next(it2))   # 输出迭代器的下一个元素
    except StopIteration:
        sys.exit()
'''
        
        
'''
在 Python 中,使用了 yield 的函数被称为生成器(generator)。
跟普通函数不同的是,生成器是一个返回迭代器的函数,只能用于迭代操作,更简单点理解生成器就是一个迭代器。
在调用生成器运行的过程中,每次遇到 yield 时函数会暂停并保存当前所有的运行信息,返回yield的值。
并在下一次执行 next()方法时从当前位置继续运行。
'''
def fibonacci(n):    # 生成器函数 - 斐波那契
    a, b, count = 0, 1, 0
    while True:
        if count > n:
            return
        yield a
        a, b = b, a + b
        print(a, b)
        count += 1
    
f = fibonacci(10)     # f 是一个迭代器,由生成器返回生成

while True:
    try:
        print(next(f), end = ":")
    except StopIteration:
        break;
        #sys.exit()

#没有yield时,函数只是简单执行,没有返回迭代器f
def fibonacci2(n):    # 生成器函数 - 斐波那契
    a, b, count = 0, 1, 0
    while True:
        if count > n:
            return
        #yield a
        a, b = b, a + b
        print(a, b)
        count += 1
    
f = fibonacci2(10)     # f 是一个迭代器,由生成器返回生成

'''
while True:
    try:
        print(next(f), end = " ")       #TypeError: 'NoneType' object is not an iterator
    except StopIteration:
        sys.exit()
'''

'''
什么情况下需要使用 yield?
一个函数 f,f 返回一个 list,这个 list 是动态计算出来的(不管是数学上的计算还是逻辑上的读取格式化),
并且这个 list 会很大(无论是固定很大还是随着输入参数的增大而增大),
这个时候,我们希望每次调用这个函数并使用迭代器进行循环的时候一个一个的得到list的每个元素
而不是直接得到一个完整的list来节省内存,这个时候 yield 就很有用。
'''
def f(n):
    a, b, count = 0, 1, 0
    L = []
    while True:
        if count > n:
            return
        L.append(b)
        a, b = b, a + b
        count += 1
    return L   #返回一个n个数的list,当这个n很大的时候,会非常的占用内存。

fun = f(1000)
'''
while True:
    try:
        print(next(fun), end = " ")   #这样我们实际上是先生成了一个1000个元素的 list:f,然后我们再去使用这个f。#TypeError: 'NoneType' object is not an iterator
    except StopIteration:
        sys.exit()
'''

#因为我们实际使用的是list的遍历,也就是list的迭代器。那么我们可以让这个函数f每次只返回一个迭代器——一个计算结果,
#而不是一个完整的 list,运行方式是每次的调用都在 yield 处中断并返回一个结果,然后再次调用的时候再恢复中断继续运行。
def f(n):
    a, b, count = 0, 1, 0
    while True:
        if count > n:
            return
        yield b
        a, b = b, a + b
        count += 1
    return L   #返回一个n个数的list,当这个n很大的时候,会非常的占用内存。

fun = f(10)
while True:
    try:
        print(next(fun), end = " ")   #这样我们实际上是先生成了一个1000个元素的 list:f,然后我们再去使用这个f。
    except StopIteration:
        sys.exit()

python系列九:python3迭代器和生成器的更多相关文章

  1. Python3+迭代器与生成器

    转载Python3 迭代器与生成器 迭代器 迭代是Python最强大的功能之一,是访问集合元素的一种方式. 迭代器是一个可以记住遍历的位置的对象. 迭代器对象从集合的第一个元素开始访问,直到所有的元素 ...

  2. python014 Python3 迭代器与生成器

    Python3 迭代器与生成器迭代器迭代是Python最强大的功能之一,是访问集合元素的一种方式..迭代器是一个可以记住遍历的位置的对象.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结 ...

  3. 完全理解 Python 迭代对象、迭代器、生成器(转)

    完全理解 Python 迭代对象.迭代器.生成器 本文源自RQ作者的一篇博文,原文是Iterables vs. Iterators vs. Generators » nvie.com,俺写的这篇文章是 ...

  4. 完全理解 Python 迭代对象、迭代器、生成器

    完全理解 Python 迭代对象.迭代器.生成器 2017/05/29 · 基础知识 · 9 评论 · 可迭代对象, 生成器, 迭代器 分享到: 原文出处: liuzhijun    本文源自RQ作者 ...

  5. 理解Python迭代对象、迭代器、生成器

    作者:zhijun liu链接:https://zhuanlan.zhihu.com/p/24376869来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 本文源自RQ作 ...

  6. Python之模块,迭代器与生成器

    本节涉及内容: 1. 迭代器和生成器 2. 递归 3. 字符串格式化 4. 模块 内置模块 自定义模块 第三方模块 5. 序列化的模块 json pickle (一). 迭代器和生成器: 迭代器:  ...

  7. python学习笔记四 迭代器,生成器,装饰器(基础篇)

    迭代器 __iter__方法返回一个迭代器,它是具有__next__方法的对象.在调用__next__方法时,迭代器会返回它的下一个值,若__next__方法调用迭代器 没有值返回,就会引发一个Sto ...

  8. python基础篇_005_迭代器和生成器

    Python迭代器和生成器 1.迭代器 迭代:可以将某个数据集内的数据“一个挨着一个的取出来” for i in range(1, 10, 2): # in 后面的对象必须是一个可迭代的 print( ...

  9. 【笔记】Python基础四:迭代器和生成器

    一,迭代器协议和for循环工作机制 (一),迭代器协议 1,迭代器协议:对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个stopiteration异常,以终止迭代(只能往 ...

  10. Python开发——函数【迭代器、生成器、三元表达式、列表解析】

    递归和迭代 小明问路篇解释说明 递归:小明——>小红——>小于——>小东:小东——>小于——>小红——>小明 小明向小红问路,因小红不知道,所以向小于问路,因小于不 ...

随机推荐

  1. (转)JavaScript: in, hasOwnProperty, delete, for/in

    in 运算符 判断对象是否拥有某一属性只要对象拥有该属性,就会返回true,否则false var point = { x:1, y:1 };alert( 'x' in point );  //tru ...

  2. margin: 0px auto; center 行类 块级

    <html> <head> <title> biaoti </title> </head> <body style="bor ...

  3. 简体字冯|docker-安装docker私有库

    原创文章,转载请注明出处. 作者:简体字丶冯; QQ:564372931 安装docker 各终端安装docker 教程 菜鸟docker教程 就挺好,本着不重复造轮子的原则就不深入了,自己学习. 如 ...

  4. Mysql 没有nvl()函数,却有一个类似功能的函数ifnull()

    今天自己无聊写了看了一个查询需求随手写了一个sql语句,发现竟然不能运行,MySQL报[Err] 1305 - FUNCTION ceshi.nvl does not exist的错.才意识到自己写的 ...

  5. Xilinx DDR3 IP核使用问题汇总(持续更新)和感悟

    一度因为DDR3的IP核使用而发狂. 后来因为解决问题,得一感悟.后面此贴会完整讲述ddr3 ip的使用.(XILINX K7) 感悟:对于有供应商支持的产品,遇到问题找官方的流程.按照官方的指导进行 ...

  6. Restore IP Addresses -- LeetCode

    原题链接: http://oj.leetcode.com/problems/restore-ip-addresses/  这道题的解法很接近于NP问题.也是採用递归的解法. 基本思路就是取出一个合法的 ...

  7. 680. Valid Palindrome II【easy】

    680. Valid Palindrome II[easy] Given a non-empty string s, you may delete at most one character. Jud ...

  8. [转]从输入url到页面加载完成的过程中都发生了什么事情

    第一个问题:从输入 URL 到浏览器接收的过程中发生了什么事情? 从触屏到 CPU 首先是「输入 URL」,大部分人的第一反应会是键盘,不过为了与时俱进,这里将介绍触摸屏设备的交互. 触摸屏一种传感器 ...

  9. App打包上架流程(iOS转)

    由于苹果的机制,在非越狱机器上安装应用必须通过官方的Appstore, 开发者开发好应用后上传Appstore,也需要通过审核等环节. AppCan作为一个跨主流平台的一个开发平台,也对ipa包上传A ...

  10. ActionBar + ViewPager(PagerSlidingTabStrip)

    既然是要实现ActionBar.那么第一步当然就是编辑menu文件夹下的main.xml文件了.代码例如以下所看到的: <menu xmlns:android="http://sche ...