python 迭代器、生成器、装饰器
一,迭代器
迭代器是访问集合元素的一种方式。迭代器对象从集合的第一个元素开始访问,知道所有的元素被访问完结束。迭代器只能往前不会后退.
特点:
访问者不需要关心迭代器内部的结构,仅需通过next()方法不断去取下一个内容
不能随机访问集合中的某个值 ,只能从头到尾依次访问
访问到一半时不能往回退
便于循环比较大的数据集合,节省内存
迭代器提供两种方法:
(1)__iter__()返回迭代器对象本身
a = iter([1,2,3,4,5])
print(a)
# <list_iterator object at 0x101402630>
print(a.__next__())#输出 1 print(a.__next__())#输出 2 print(a.__next__())# 输出3 print(a.__next__())# 输出4 print(a.__next__())# 输出5 print(a.__next__()) #超过后就会报错
(2)__next__()返回迭代器的下一个元素
names = iter(['liu', 'yao', 'sb']) print(names) print(names.__next__()) print(names.__next__()) print('暂停') print(names.__next__()) 输出:
<list_iterator object at 0x0000000001199898>
liu
yao
暂停
sb
(3)for...in..方法
for使用了列表支持迭代器的性质,可以每次通过调用迭代器的next()方法,来遍历到列表中的值,直到遇到StopIteration的异常
li = [1, 2, 3, 4] for i in li:
print(i)
二,生成器
定义:
一个函数调用时返回一个迭代器,那这个函数就叫做生成器(generator);
如果函数中包含yield语法,那这个函数就会变成生成器
它基于yield指令,允许停止函数并立即返回结果
特点:
在每次调用next()的时候执行,遇到yield语句返回,再次执行时从上次返回的yield语句处继续执行
def xrange(): #带yield为生成器函数
print(11)
yield 1 print(22)
yield 2 print(33)
yield 3 r = xrange() #仅获取到第一个生成器
#生成器的__next__方法
ret = r.__next__() #获取第一次
print(ret) ret = r.__next__()#记住上次执行的,进行寻找下一个yield,再进行执行。
print(ret) ret = r.__next__()#获取第三次,如果上面没有yield可执行就报错,
print(ret)
示例
def xrangs(n):
start = 0
while True:
if start > n:
return
yield start
start += 1 obj = xrangs(5)
n1 = obj.__next__()
n2 = obj.__next__()
n3 = obj.__next__()
n4 = obj.__next__()
n5 = obj.__next__()
n6 = obj.__next__()
print(n1,n2,n3,n4,n5,n6) 输出:
0 1 2 3 4 5
三,装饰器
装饰器就是把函数的名字传入进去, 在执行函数之前, 进行一些提前的处理.
装饰器本身就是一个函数, 将所装饰的函数, 作为一个参数传进来,
然后在执行这个函数之前, 进行一个处理,这就是装饰器. 所以和正常函数执行顺序是一样的..
例:如果一个公司有运维部,开发部,测试部,设计部,等,并且公司具有基础平台架构,为公司各个部门提供数据库调用,资料查看,监控等。
当这些部门想使用这些功能的时候,直接调用这些功能的接口就可以,如下:
######基础平台提供的功能------------ def 功能1() print ('功能1') def 功能2() print ('功能2') def 功能3() print ('功能3') def 功能4() print ('功能4')
当运维部门调用的时候如下:
def 功能1() def 功能2() def 功能3()
当开发部门调用的时候如下:
def 功能1() def 功能2() def 功能3()
之后要为平台提供的所有功能添加验证机制,
基础平台提供如下功能接口:
1.让各个部门修改自己的代码
2.在每个部门实现的功能上加上代码
3.把验证代码变成函数 在每个功能上加入
4.为了追寻开放封闭原则
利用装饰器的功能实现
def login(func): def inner(): # 验证1 # 验证2 # 验证3 return func() return inner @login def 功能1(): print '功能1' @login def 功能2(): print '功能2' @login def 功能3(): print '功能3' @login def 功能4(): print '功能4'
当各个部门执行 def 功能的时候
def login(func): def inner(): # 验证1 return func() return inner @login def 功能1(): print '功能1'
当调用功能1的时候 会先把功能1的函数名带入内存地址,之后会执行login函数,func为功能1,
之后inner会将功能1的参数带入等待执行inner的验证功能后,
会将参数交给func执行功能1的命令。
实例:
1)一个装饰器
#有参数的装饰器
def outer(func):
def inner(a1,a2):
print("")
# ret = func(a1,a2)
print("")
ret = func(a1,a2) #执行index函数
return ret
return inner @outer
def index(a1,a2):
print("非常复杂")
return a1 + a2 #只要函数应用装饰器,那么函数就被重新定义,重新定义为:装饰器的内层函数
index(1,2)
2)万能的装饰器
#万能的装饰器 def outer(func):
def inner(*arg,**kwargs):
print("")
# ret = func(a1,a2)
print("")
ret = func(*arg,**kwargs) #执行index函数
return ret
return inner @outer
# @outer
# 1、执行outer函数,将index作为参数传递
# 2、将outer的返回值,重新赋值给index def index(a1,a2):
print("非常复杂")
return a1 + a2 #只要函数应用装饰器,那么函数就被重新定义,重新定义为:装饰器的内层函数
index(1,2,)
3)多个装饰器
#两个装饰器 def outer_0(func):
def inner(*arg,**kwargs):
print("3.5")
ret = func(*arg,**kwargs)
return ret
return inner def outer(func):
def inner(*arg,**kwargs):
print("")
# ret = func(a1,a2)
print("")
ret = func(*arg,**kwargs) #执行index函数
return ret
return inner @outer_0
@outer
def index(a1,a2):
print("非常复杂")
return a1 + a2 #只要函数应用装饰器,那么函数就被重新定义,重新定义为:装饰器的内层函数
index(1,2,) @outer
def f1(a1,a2,a3):
print("f1")
return f1 f1(6,7,8)
¥
python 迭代器、生成器、装饰器的更多相关文章
- Python 迭代器&生成器,装饰器,递归,算法基础:二分查找、二维数组转换,正则表达式,作业:计算器开发
本节大纲 迭代器&生成器 装饰器 基本装饰器 多参数装饰器 递归 算法基础:二分查找.二维数组转换 正则表达式 常用模块学习 作业:计算器开发 实现加减乘除及拓号优先级解析 用户输入 1 - ...
- 4.python迭代器生成器装饰器
容器(container) 容器是一种把多个元素组织在一起的数据结构,容器中的元素可以逐个地迭代获取,可以用in, not in关键字判断元素是否包含在容器中.通常这类数据结构把所有的元素存储在内存中 ...
- Python迭代器&生成器&装饰器
1. 迭代器 1.1 可迭代对象(Iterator) 迭代器协议:某对象必须提供一个__next__()方法,执行方法要么返回迭代中的下一项,要么引起一个Stopiteration异常,以终止迭代(只 ...
- Python迭代器,生成器,装饰器
迭代器 通常来讲从一个对象中依次取出数据,这个过程叫做遍历,这个手段称为迭代(重复执行某一段代码块,并将每一次迭代得到的结果作为下一次迭代的初始值). 可迭代对象(iterable):是指该对象可以被 ...
- Python(迭代器 生成器 装饰器 递归 斐波那契数列)
1.迭代器 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退.另外,迭代器的一大优 ...
- Python基础-迭代器&生成器&装饰器
本节内容 迭代器&生成器 装饰器 Json & pickle 数据序列化 软件目录结构规范 作业:ATM项目开发 1.列表生成式,迭代器&生成器 列表生成式 我现在有个需求,看 ...
- 迭代器/生成器/装饰器 /Json & pickle 数据序列化
本节内容 迭代器&生成器 装饰器 Json & pickle 数据序列化 软件目录结构规范 作业:ATM项目开发 1.列表生成式,迭代器&生成器 列表生成式 孩子,我现在有个需 ...
- Day04 - Python 迭代器、装饰器、软件开发规范
1. 列表生成式 实现对列表中每个数值都加一 第一种,使用for循环,取列表中的值,值加一后,添加到一空列表中,并将新列表赋值给原列表 >>> a = [0, 1, 2, 3, 4, ...
- python学习笔记(5)--迭代器,生成器,装饰器,常用模块,序列化
生成器 在Python中,一边循环一边计算的机制,称为生成器:generator. 如: >>> g = (x * x for xin range(10)) >>> ...
- python中的迭代器&&生成器&&装饰器
迭代器iterator 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束. 迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退.另外, ...
随机推荐
- MySQL和MongoDB语句的写法对照
查询: MySQL: SELECT * FROM user Mongo: db.user.find() MySQL: SELECT * FROM user WHERE name = ’starlee’ ...
- html之p标签
p标签定义段落 p元素会自动在其前后创建一些空白,浏览器会自动添加这些空间. 效果图:
- Anaconda多环境多版本python配置指导
Anaconda多环境多版本python配置指导 字数3696 阅读644 评论0 喜欢0 最近学python,读完了语法后在GitHub找了一些练习来做,由 于学的是python3.x语法,而Git ...
- 常见的java 错误--转
Java常见错误列表: 找不到符号(symbol) 类X是public的,应该被声明在名为X.java的文件中 缺失类.接口或枚举类型 缺失X 缺失标识符 非法的表达式开头 类型不兼容 非法的方法声明 ...
- C转义字符
C语言输出特殊字符 C语言转义字符意义大体同于前面的C#转义字符,这里列出用c语言,输出%d.\n等特殊字符的方法. #include <stdio.h> int main() { pri ...
- MySQL 使用mysqld_multi部署单机多实例详细过程 (转)
随着硬件层面的发展,linux系统多核已经是普通趋势,而mysql是单进程多线程,所以先天上对多进程的利用不是很高,虽然 5.6版本已经在这方面改进很多,但是也没有达到100%,所以为了充分的利用系统 ...
- 微信公众号开发笔记(C#)
这篇文章还不错,使用 .net , 对微信用户的想公众号发送的文字进行回复.比较简单,自己可以修改更复杂的回复. 微信公众号开发笔记(C#) 原文地址 需求分析 根据用户在微信上发送至价值中国公众号 ...
- [spring security] spring security 4 基础Demo
依赖包: <properties> <junit.version>4.11</junit.version> <spring.version>4.1.6. ...
- Hibernate延迟加载机制详解
摘自 http://blog.chinaunix.net/uid-20577907-id-3129234.html 1 延迟加载: 延迟加载机制是为了避免一些无谓的性能开销而提出来的,所谓延迟加载就是 ...
- cmd命令运行php,php通过cmd运行文件
一.cmd命令运行php 1.通过配置环境变量 >php "php文件" 如果要待参数 php -q "php文件" 参数 php获取参数 $a = $a ...