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' 关键字的函数. 当生成器函数被 ...
随机推荐
- 异常处理之“The remote certificate is invalid according to the validation praocedure.”
参考文章:http://brainof-dave.blogspot.com.au/2008/08/remote-certificate-is-invalid-according.html 参考文章:h ...
- nginx在linux下安装
安装前先确认是否已经安装编译包和一些依赖包如果没有安装: yum install pcre* yum install openssl* yum install zlib yum install zli ...
- 前端之float的几种清除浮动方式
前端之float的几种清除浮动方式 本节内容 1.float清除方式1 2.float清除方式2 3.float清除方式3 4.float清除方式4 1.float清除方式1 <!DOCTYPE ...
- sql
http://www.cnblogs.com/ASPNET2008/archive/2012/06/30/2570737.html
- BZOJ 4008 【HNOI2015】 亚瑟王
题目链接:亚瑟王 这道题好神啊TAT--果然我的dp还是太弱了-- 一开始想了半天的直接dp求期望,结果最后WA的不知所云-- 最后去翻了题解,然后发现先算概率,再求期望--新姿势\(get\). 我 ...
- [LeetCode] Fizz Buzz 嘶嘶嗡嗡
Write a program that outputs the string representation of numbers from 1 to n. But for multiples of ...
- WIN10下安装HBASE教程
工作需要,现在开始做大数据开发了,通过下面的配置步骤,你可以在win10系统中,部署出一套hadoop+hbase,便于单机测试调试开发. 准备资料: 1. hadoop-2.7.2: https:/ ...
- phpmyadmin not found
在 ubuntu 14.04 中使用: > sudo apt-get install phpmyadmin 安装好 phpmyadmin 之后,打开 http://localhost/phpmy ...
- 未能写入输出文件“c:\Windows\Microsoft.NET\Framework64\v4.0.30319\Temporary ASP.NET Files\root\106f9ae8\cc0e1
在本地开发环境没问题,但是发布到服务器出现:未能写入输出文件"c:\Windows\Microsoft.NET\Framework64\v4.0.30319\Temporary ASP.Ne ...
- beanstalkd 消息队列
概况:Beanstalkd,一个高性能.轻量级的分布式内存队列系统,最初设计的目的是想通过后台异步执行耗时的任务来降低高容量Web应用系统的页面访问延迟,支持过有9.5 million用户的Faceb ...