python 生成器等语法
生成器
调用生成器函数,不会执行生成器函数中的代码,而是返回一个对象, 这个对象是生成器(可用type()函数判断这个对象类型), 如果要运行生成器函数中的代码, 需要调用 next()方法, next()方法会在遇到 yield 语句的地方停止运行.
不停地调用生成器对象的 next()方法,即可获得一个序列。
一般不需要直接调用 next()方法,而是使用 for 语句:
def countdown(n): print 'counting down from %d'%n while n>0: yield n n -= 1 for n in countdown(10): print n a = sum(countdown(10))
传递给 yield 的值,会通过next()方法返回。
next()方法 当遇到yield时暂停函数的执行,并返回。当下一次再调用next()时恢复函数的执行. 可以通过打印信息来说明生成器的执行情况。
生成器函数在每次暂停执行时,函数体内的所有变量都将被封存(freeze)在生成器中.
def countdown(n): print '---------1' while n > 0: print '---------2' yield n print '---------3' n -= 1 print '---------4'
调用生成器,并查看运行情况:
c = countdown(5) c.next() c.next() c.next()
当生成器函数返回 , 或者 抛出 StopIteration 时, 生成器才运行完. 生成器函数除了返回None ,其它类型的返回值都是非法的.
可以调用生成器的close方法来终止生成器的运行. close()方法会触发 GeneratorExit异常,可在生成器函数中捕获,并做一些清理工作.
协程和yield 表达式
在函数中,yield语句也可以作为 一个表达式出现在赋值符号的右边 , 如:
def receiver(): print 'ready to receive' while True: n = (yield) print 'Got %s'%n
当函数以这种方式使用 yield 时 , 这个函数称为 coroutine ( 协程 ). 它对发送给他的值做出响应。
一般函数只处理单个的输入参数集合, 而协程则是对一连串发送给它的输入参数进行处理。 协程是通过 yield 语句创建的。
传递给send()的参数 ,会被 yield表达式返回。
装饰器
装饰器是一个函数,其主要目的是封装另外一个函数或者类。
@trace def square(x): return x*x #上面的装饰器是以下代码的简写 def square(x): return x*x square = trace(square) #square已经是另一个函数了.
经过装饰器修饰过的函数,当实际调用时,调用的已经不是被修饰的函数,而是另一个新的函数。
装饰器也能够接受参数:
@eventhandler('button') def handle_button(msg): .... #实际的调用过程为 temp = eventhandler('button') handle_button = temp(handle_button)
修饰类的装饰器
由于装饰器是一个函数,当它修饰类时,则这个函数需要返回类的对象。(对于修饰类的装饰器返回函数也是可以的,只是如果是返回函数,如果要访问对象的成员,则没法访问)
@foo class Bar(object): def __init__(self,x): self.x = x def spam(self): statements
列表解析和生成器表达式
生成器和列表解析基本功能是一样的, 一点微小的差别是 生成器表达式使用小括号, 而列表解析使用中括号.
并且在列表解析中, python实际上是创建一个包含结果数据的列表; 在生成器表达式中, python创建的是一个生成器对象, 它知道如何根据需要来产生数据.
declarative programming
lambda 运算符
表达式形式的匿名函数,可以通过 lambda 语句. 如:
lambda args : expression
args 是逗号分隔的参数. expression是设计到这些参数的表达式. 例如:
a = lambda x, y : x + y r = a(2,3) #r == 5
expression必须是一个有效的表达式, 多条语句和其他非表达式的语句, 例如 for , while 不能出现在 lambda 语句中.
lambda 主要的用法是定义简短的回调函数.
Recursion 递归
可以很轻易定义递归函数,例如:
def factorial(n): if n <= 1: return 1 else: return n * factorial(n-1)
但是需要注意递归的深度问题. sys.getrecursionlimit() 函数返回递归的最大允许深度. (受限于主机的栈空间大小). 超过最大深度, 程序可能会抛出 RuntimeError 异常.
python 生成器等语法的更多相关文章
- python yield from 语法
python yield from 语法 yield语法比较简单, 教程也很多 , yield from的中文讲解很少 , python官网是这样解释的 PEP 380 adds the yield ...
- [译]PEP 380--子生成器的语法
导语: PEP(Python增强提案)几乎是 Python 社区中最重要的文档,它们提供了公告信息.指导流程.新功能的设计及使用说明等内容.对于学习者来说,PEP 是非常值得一读的第一手材料,学习中遇 ...
- 四. Python基础(4)--语法
四. Python基础(4)--语法 1 ● 比较几种实现循环的代码 i = 1 sum = 0 while i <= 10: # 循环10-1+1=10次 sum += i i ...
- Python 生成器总结
生成器的概念: 生成器不会把结果保存在一个系列中,而是保存在生成器的状态,在每次进行迭代时返回一个值,直到遇到StopIteration异常结束 生成器是这样一个函数,它记住上一次返回时在函数体中的位 ...
- python生成器,函数,数组
1.什么是生成器用一个比喻来形容,工厂中生产保龄球的流水线,机器每次只生产一个保龄球,下次继续生产下一个,直到停止(原料不足,停止供电等条件)为止.机器就是我们的生成器. 2.使用示例在python中 ...
- python语句和语法
python语句和语法 python程序结构: 1.程序由模块构成. 2.模块包含语句. 3.语句包含表达式. 4.表达式建立并处理对象. python的语法实质上是有语句和表达式组成的.表达式处理对 ...
- python 生成器与迭代器(yield 用法)
背景 首先,我不会解释这两个名词,我看过很多遍解释,可还是看不懂,还是直接看使用情景吧. 我们以佩波拉契数列为例,当我们不知道迭代器的情况下,我们写出来的代码可能是这样子的: '''这种方式计算fib ...
- 【python之路29】python生成器generator与迭代器
一.python生成器 python生成器原理: 只要函数中存在yield,则函数就变为生成器函数 #!usr/bin/env python # -*- coding:utf-8 -*- def xr ...
- Generator - Python 生成器
Generator, python 生成器, 先熟悉一下儿相关定义, generator function 生成器函数, 生成器函数是一个在定义体中存有 'yield' 关键字的函数. 当生成器函数被 ...
随机推荐
- prompt() 方法,弹框带输入框
prompt() 有alert的风格,却带着输入框,这是怎么实现的呢? 语法 prompt(text,defaultText) 参数 描述 text 可选.要在对话框中显示的纯文本(而不是 HTML ...
- mysql workbench如何把已有的数据库导出ER模型
mysql workbench的特长是创建表结构的,然后在结构图中,圈圈点点,很容易就利用可视化方式把数据库建好,然后再导入到数据库服务器中,这种办法很效率.但是有时我们有一个需求,事先没有建表结构模 ...
- Hadoop 2.x
Hadoop 2.x 生态系统及技术架构图 一.负责收集数据的工具:Sqoop(关系型数据导入Hadoop)Flume(日志数据导入Hadoop,支持数据源广泛)Kafka(支持数据源有限,但吞吐大) ...
- Codevs堆练习
Codevs堆练习 黄金:2830.2879.2995.3110 钻石:1052.1063.1245.1246.2057.2573.3377 大师:1021.1765.2069.2913.3032
- [LeetCode] Non-overlapping Intervals 非重叠区间
Given a collection of intervals, find the minimum number of intervals you need to remove to make the ...
- [LeetCode] Construct Binary Tree from Preorder and Inorder Traversal 由先序和中序遍历建立二叉树
Given preorder and inorder traversal of a tree, construct the binary tree. Note:You may assume that ...
- DDR相关的低功耗技术之PASR、TCSR、DPD
随着智能机的发展,DDR内存容量越来越大,bank数量越来越多,功耗也越来越大.在不需要的时候关闭部分bank,或者降低自刷新频率,或者进入深度低功耗模式.有三种DDR技术用来降低功耗: PASR(P ...
- C#计算代码执行时间
System.Diagnostics.Stopwatch watch = new Stopwatch();watch.Start(); //要计算的操作 DoSomeThing(); watch.St ...
- ubuntu系统虚拟机下共享文件夹
一般情况 1.安装: sudo apt-get install open-vm-dkms 2.挂载: sudo mount -t vmhgfs .host:/ /mnt/hgfs 用以上命令安 ...
- 分享一些自己的学习过程和学习方法(来自daimajia)
每天,都会有人在微博上私信我,问我关于学习和成长的问题.这种问题我一般都不会回复某个j,毕竟每个人的情况不一样,每个人对待事物的性格也不一样,我不能夸下海口的说,你看某本书几个月就能如何如何,我能做的 ...