一.生成式和生成器
  列表生成式是python受欢迎的语法之一,通过一句简洁的语法就可以对一组元素进行过滤,还可以对得到的元素进行转换处理。
 
#/usr/bin/python
#coding=utf-8
#@Time   :2017/11/2 21:05
#@Auther :liuzhenchuan
#@File   :列表生成式和生成器.py
 
#求1-100里所有偶数的平方
#列表生成式法
print [x*x for x in xrange(1,101) if x%2==0]
 
#定义函数 for遍历方法
def fun():
    a = []
    for i in xrange(1,101):
        if i%2==0:
            a.append(i*i)
    return a
print fun()
 
>>> [4, 16, 36, 64, 100, 144.....10000]
>>> [4, 16, 36, 64, 100, 144.....10000]
 
 
 
2.通过列表生成式,我们可以直接创建一个列表。但是,收到内存限制,列表容量肯定是有限的。而且,创建一个包含100万个元素的列表,不仅占用很大的内存空间,如果我们仅仅需要访问前面几个元素,那后面绝大多数元素占用的空间都白白浪费了。所以,如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的元素呢?这样就不必创建完整的list,从而节省大量的空间,在python中,这种一遍循环一边计算的机制,称为生成器(generator)。
   要创建一个generator,有很多方法。第一种方法是把一个列表生成式的[]改成(),就创建了一个generator。
 
示例:
##列表生成器
#1.要创建一个列表生成器,最简单的办法就是把[] 换成()
lt =(x*x for x in xrange(1,101) if x%2==0)
print lt
print type(lt)
 
##通过next()方法,查看列表生成器,当next()最后一个时,next就会报错
print lt.next()
print lt.next()
print lt.next()
 
>>> <generator object <genexpr> at 0x0372F508>
<type 'generator'>
4
16
36
 
#通过循环方法读取列表生成器的值
lt1 = [51,2,3,5,10,18,60]
for x in lt1:
        print lt1
>>> [51, 2, 3, 5, 10, 18, 60]
    [51, 2, 3, 5, 10, 18, 60]
 
#generator保存的是算法,每次调用next(),就统计算出下一个元素的值。知道计算机到最后一个元素为止。
 
#2 定义generator的另一种方法,如果一个函数定义中包含yield关键字,那么这个函数就不再是一个普通函数,而是一个generator
  #yield 的使用
  ##求10以内数的和
def fib(n):
    i =
    while i < n:
        sum += i
        i +=
        print sum
    print '和为:%d' % sum
fib(10)
 
print '########当我把第一个sum前加yield时'
 
def fib(n):
    i =
    while i < n:
        sum += i
        i +=
        yield(sum)
    print '和为:%d' % sum
fib(10)
print type(fib(10))
for i in fib(10):
    print i
 
>>>
0
1
3
6
10
15
21
28
36
45
和为:45
########当我把sum前加yield时,print fib 类型就是成了生成器了
<type 'generator'>
0
1
3
6
10
15
21
28
36
45
和为:45
 
   两次程序的结果和都一样,但是有什么不同呢,简而言之,包含yield语句的函数会被特地编程成生成器,当函数被调用时,他们返回一个生成器对象,这个对象支持迭代器接口,每当遇到yield关键字的时候,你可以理解成函数的return语句,yield后面的值,就是返回的值。但是不像一般的函数在return后退出,生成器函数在生成值后悔自动挂起并暂停他们的执行和状态,他的本地变量将保存状态信息,这些信息在函数恢复时将再度有效,下次从yield下面的部分开始执行。
    解释:1 . 以上函数有关键字yield,所以生成的是一个生成器。
                2. 通过for循环调用生成器,当执行到yield的时候,返回sum的值,sum为0,此时暂停并记录sum的值
                3. 打印sum的值,然后继续往下执行,此时跳入一个循环while[1<10]
                4. 直到遇到yield 的时候,返回sum值。
                 5. 反复执行3,4步骤,知道循环结束,最终程序退出。
 
  二者的区别很明显:
       一个直接返回了表达式的结果列表,而另一个是一个对象,该对象包含了对表达式结果的计算引用,通过循环可以直接输出
        生成器不会一次性列出所有的数据,当你用到的时候,在列出来,更加节约内存的使用。
 
 

二.迭代器
iterable(可迭代对象) 和 iterator(迭代器) 主要区别是:
1. 凡是可以用for循环的都是iterable(可迭代对象)  ,凡是需要通过next() 函数获得值得可迭代对象都是iterator(迭代器)
  2. 所以生成器可以被next() 函数调用并不断返回下一个值得对象称为迭代器
  3. 可以简单的理解为生成器就是迭代器的可迭代对象
 
凡是可作用于for 循环的对像都是iterable 类型
 
凡是可作用于next()函数的对象都是iterator 类型,他们表示一个惰性计算的序列。
 
 
#生成式:一次生成所有的数据,然后保存在内存当中,适合小量的数据
#生成器:返回一个可迭代的对象,及'generator'对象,必须通过循环才可以一一 取出所有的结果
#可迭代对象:可以通过循环调用出来的,就是可迭代对象。 可迭代对象包括: []  () {}  生成式  生成器
# 迭代器: 可以简单理解为生成器 。必须通过next() 函数调用并不断返回下一个值得对象就是迭代器。
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

python 基础 4.4 生成式 生成器 迭代器的更多相关文章

  1. Python学习之路7 - 生成器&迭代器

    本章内容: 列表生成式 生成器 yield 迭代器 列表生成式 当我们要定义一个列表的时候,我们通常用这种方式a = [1,2,3],但是如果我们定义了一个比较长的列表的时候,手动定义列表就会比较麻烦 ...

  2. Python之旅Day5 列表生成式 生成器 迭代器 装饰器

    装饰器 器即函数,装饰即修饰,意指为其他函数添加新功能 装饰器定义:本质就是函数,功能是为其他函数添加新功能 装饰器涉及的知识点= 高阶函数+函数嵌套+闭包 在遵循下面两个原则的前提下为被装饰者新功能 ...

  3. python基础-装饰器,生成器和迭代器

    学习内容 1.装饰器 2.生成器 3.迭代器 4.软件目录结构规范 一:装饰器(decorator) 1.装饰器定义:本质就是函数,用来装饰其他函数,即为其他函数添加附加功能. 2.装饰器原则:1)不 ...

  4. python基础:列表生成式和生成器

    列表生成式(List Comprehension) 列表生成式即List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式. 举个例子,要生成 list ...

  5. Python基础(8)_迭代器、生成器、列表解析

    一.迭代器 1.什么是迭代 1 重复 2 下次重复一定是基于上一次的结果而来 l=[,,,] count= while count < len(l): print(l[count]) count ...

  6. Python基础_可迭代的/迭代器/生成器

    介绍 可迭代的:内部实现了__iter__方法 迭代器:内部实现了__iter__,__next__方法 生成器:yield,yield from 使用 __iter__() __next__() _ ...

  7. 跟着ALEX 学python day4集合 装饰器 生成器 迭代器 json序列化

    文档内容学习于 http://www.cnblogs.com/xiaozhiqi/  装饰器 : 定义: 装饰器 本质是函数,功能是装饰其他函数,就是为其他函数添加附加功能. 原则: 1.不能修改被装 ...

  8. 列表生成式 生成器 迭代器 yield

    列表生成式 格式:通过一个或者若干个在List里边的for构建List而非List外部的for循环 举个例子:计算从1到10整数的平方构成一个List L=[ x*x for x in range(1 ...

  9. python基础--异常,对象和迭代器

    异常处理 面向对象 迭代器和生成器 python异常处理 下面代码触发了一个FileNotFoundError >>> open("notexist.txt") ...

随机推荐

  1. 多线程中sleep和wait的区别

    前几天去UC笔试,有一道简答题问到了.之前还真一直没留意到这个问题,所以答得也不好. 无论学习什么都好,通过对比学习更有利于发现事物的共性和个性,对于知识点的理解更有明显效果(这也可能是UC笔试题上, ...

  2. (21)Oracle表查询进阶

    转到基本查询 一.多表查询 笛卡尔积:每张表的列数相加,行数相乘. 连接条件:得出笛卡尔积后需要用where条件筛选出正确的数据.连接条件至少需要n张表减1个 1.等值连接 连接条件为等号 selec ...

  3. LOJ N!在不同进制的位数

    lightoj1045 - Digits of Factorial (N!不同进制的位数) 对于一个B进制的数,只需要对其取以B的对数就可以得到他在B进制情况下的位数(取了对数之后可能为小数,所以还需 ...

  4. 洛谷——P2626 斐波那契数列(升级版)

    P2626 斐波那契数列(升级版) 题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) (n ≥ ...

  5. 10.1综合强化刷题 Day2 afternoon

    最大值(max) Time Limit:1000ms   Memory Limit:128MB 题目描述 LYK有一本书,上面有很多有趣的OI问题.今天LYK看到了这么一道题目: 这里有一个长度为n的 ...

  6. Ruby 定时任务之一(初步尝试)

    最近工作需要用到定时任务.原来写java的时候也用到过类似的Scheduler的功能. Ruby语言中也有同样功能的工具.rufus-scheduler.下面介绍一下rufus-scheduler. ...

  7. OpenSSL使用2(SSL,X.509,PEM,DER,CRT,CER,KEY,CSR,P12概念说明)(转)

    SSL SSL - Secure Sockets Layer,现在应该叫"TLS",但由于习惯问题,我们还是叫"SSL"比较多.http协议默认情况下是不加密内 ...

  8. ios iPhone 如何将应用程序名称本地化

    iPhone的应用程序名称也可以本地化,可以按照以下步骤来实施: 1. 修改项目目录下的’ -info.plist’文件名 将’ -info.plist’ 修改为 Info.plist 2. 将Inf ...

  9. Android Retrofit使用教程

    Square公司开源了许多优秀的库,Retrofit就是其中之一. Retrofit是用来简化APP访问服务器API,如果你的服务器使用的使RESTAPI,那么赶紧使用Retrofit吧. 官方的文档 ...

  10. eos智能合约与主进程交互

    eos智能合约与主进程交互 1.启动wasm 参考eos智能合约执行流程.md 2.智能合约调用主进程api 如何实现wasm代码与eos宿主交互还需要摸索! 大致:在wasm_interface.c ...