列表生成式 生成器 迭代器 yield
列表生成式
格式:通过一个或者若干个在List里边的for构建List而非List外部的for循环
举个例子:计算从1到10整数的平方构成一个List
L=[ x*x for x in range(1,11) ]
作用:①取代for循环+append快速生成一个List
②从已有的List中快速生成另一个List
补充:
1、for后可以跟 if,以达到筛选合适的元素而非全部元素以创建List
如:只取偶数
L=[ x*x for x in range(1,11) if not x%2]
注意:for后的if为筛选,不能跟else
for后的if会只筛选出符合条件的x用以构建List
for前可以跟if…else …,此时if…else…为表达式,不起筛选作用(即不会减少List中的元素个数)
L=[x if x%2 else -x for x in range(1,11)]
[1, -2, 3, -4, 5, -6, 7, -8, 9, -10]
相当于
for x in range(1,11):
if x % 2: #为偶数
x=x #不变
else:
x=-x
2、可以两个变量同时参与
L=[ m+n for m in 'abc' for n in 'xyz']
['ax', 'ay', 'az', 'bx', 'by', 'bz', 'cx', 'cy', 'cz']
效果类似于两层循环,第一个for对应外层循环,第二个for对应内层循环
3、当然两个变量同时参与也可以不用两个for
例如对Dict的Key和Value的访问
1 D={'Mike':23,'Bob':19,'Jim':20}
2 L=[ m+':'+str(n) for m,n in D.items()]
3
4 L
5 ['Mike:23', 'Bob:19', 'Jim:20']
注意第二行,只有相同类型才能用加号+,所以要对整数类型n进行强制类型转换
这样的话,2和3看起来就和for循环区别很小了,只是把for循环的循环体放在了for循环前边
应用:
1、用简洁的语句列出当前目录下的所有文件名
import os
[D for D in os.listdir('.')] ['.idea', 'Fib.py', 'Hanoi.py', 'T1.py', 'venv']
os是模块方面的内容,以后会学到
2、将一个列表List中的所有字符串中的字符小写
方法:字符串的lower方法,str.lower(),如果是大写则是upper方法
注意,如果该List中既有字符串,又有其他类型,则需要for后if筛选
L=[ 'Abc' , 123 , 'MNO' ,True]
A=[s.lower() for s in L if isinstance(s,str)] A
['abc', 'mno']
生成器
意义:生成列表List过大时,为节省空间,不把List中的每个元素都保存下来,而是根据算法,需要时通过迭代计算出指定的值
Python这种边迭代边计算的机制叫做生成器(Generator)
创建:
①把列表生成式的中括号[ ]变为小括号( )即可
G=(x*x for x in range(1,11))
②通过函数创建,利用yield关键字
如果一个函数中包含了yield关键字,那它就不是一个普通的函数,而是一个Generator。
!!!普通函数是遇到return返回,而对于Generator,是在每次调用next()方法的时候执行,遇到yield语句返回,再次执行时,从上次返回的yield语句后一句继续执行。可以理解为,yield就是generator的return
举个例子:
def odd():
print ('step 1')
yield 1
print ('step 2')
yield 2
print ('step 3')
yield 3 o=odd()
next(o)
step 1
1 next(o)
step 2
2 next(o)
step 3
3
odd()是一个Generator,遇到next()才会执行,遇到yield就返回,每次执行都是从上次的yield处继续的。执行了3次next()后,已经没有yield了,所以再调用next()就会报错
访问元素
注意:不能通过下标 [ N ] 的方式访问generator的特定元素
①一个接一个打印
不断用next方法,python2.x中的方法是generator.next();python3.x中的方法是next(generator)
G=(x*x for x in range(1,11)) next(G)
1
next(G)
4
next(G)
9
无法next时,会抛出StopIteration错误
②for循环
Generator也是可迭代对象,可以通过for迭代
for i in G:
print (i) 16
25
…
100
由于之前已经next()了3次,所以无法从头输出,只能从第四次开始
需要注意的是,用for迭代对generator进行操作,相当于进行了相同次数的next(),因此可以继续next()的次数减少了
补充:要访问某个特定元素,需要先迭代一定次数,而无法直接访问,换言之,这个元素没有保存在内存中,而是实时计算得到的
实例
Fibonacci数列:
def Fib2(num):
n=1;a=0;b=1;
while n<num:
print (b)
s=a
a=b
b+=s
n+=1
return
Fib数列可以根据初始两个值,推算出后续任意值,这与Generator十分相似,如果我们指明是对哪个变量运用了推算规则,我们就可以把这个函数变为Generator
方法是,将print改为yield,这意味着,我们用yield标识了这个根据算法推算出来的变量b,则这个变量就是构成Generator的那个变量(这里说法不严谨,但一时找不出更适合的词语)
如果一个函数变为了Generator,我们便可以通过for循环访问其中的元素;next()也可以,但不如for简洁
for i in Fib2(6):
print (i) 1
1
2
3
5
补充:Generator函数可以用一个变量承接,如
F=Fib2(6)
这样可以更直观地看出来是Generator而非普通的函数
另外,普通函数调用返回值是一个确定的值,Generator返回的是一个Generator
迭代器
可迭代对象(Iterable):可以直接用于for循环的数据类型;
两种:
1、集合类数据——Dict List Tuple Str
2、迭代器Iterator
迭代器(Iterator):可以被next( )函数调用,并不断返回下一个值的对象,直到最后抛出StopIteration错误表示无法继续返回下一个值
举例:Generator(两种:1、生成器 2、带yield的Generator函数)
可以用isinstance函数判断某数据是否为Iterable或者Iterator
#这里的A表变量,不表字母A
isinstance(A , Iterable) isinstance(A , Iterator)
检查前应先从collections库中导入Iterator类
from collections.abc import Iterator
将Iterable转化为Iterator:iter()函数
from collections.abc import Iterator isinstance(iter([]),Iterator)
True
Python对于Iterator的处理——当做一个数据流,只能通过next()不断返回下一个数据,它是一个惰性数列——不存储所有值,而是需要时才计算出想要的值。
Python中for循环的实质是将Iterable转化为Iterator,再通过不断的next()实现的
for x in [1,2,3,4,5]:
pass #等价于 it=iter( [ 1,2,3,4,5 ] )
while True:
try:
x=next( it )
except StopIteration :
break
列表生成式 生成器 迭代器 yield的更多相关文章
- Python之旅Day5 列表生成式 生成器 迭代器 装饰器
装饰器 器即函数,装饰即修饰,意指为其他函数添加新功能 装饰器定义:本质就是函数,功能是为其他函数添加新功能 装饰器涉及的知识点= 高阶函数+函数嵌套+闭包 在遵循下面两个原则的前提下为被装饰者新功能 ...
- python协程函数应用 列表生成式 生成器表达式
协程函数应用 列表生成式 生成器表达式 一.知识点整理: 1.可迭代的:对象下有_iter_方法的都是可迭代的对象 迭代器:对象._iter_()得到的结果就是迭代器 迭代器的特性: 迭代器._n ...
- python 基础 4.4 生成式 生成器 迭代器
一.生成式和生成器 列表生成式是python受欢迎的语法之一,通过一句简洁的语法就可以对一组元素进行过滤,还可以对得到的元素进行转换处理. #/usr/bin/python #coding=u ...
- 列表生成式,迭代器&生成器
python3中range(10)就 是迭代器 列表生成式 #列表生成式 a=[0,1,2,3,4,5] b=[] for index,i in enumerate(a): a[index]+1 pr ...
- Day4- Python基础4 深浅拷贝、三目运算、列表生成式,迭代器&生成器、装饰器
本节内容: 1.深浅拷贝 2.三目运算 3.迭代器和生成器 4.装饰器 1.深浅拷贝 拷贝意味着对数据重新复制一份,深浅拷贝的含义就是:对于修改复制的数据是否会影响到源数据,拷贝操作对于基本数据结构需 ...
- s14 第4天 关于python3.0编码 函数式编程 装饰器 列表生成式 生成器 内置方法
python3 编码默认为unicode,unicode和utf-8都是默认支持中文的. 如果要python3的编码改为utf-8,则或者在一开始就声明全局使用utf-8 #_*_coding:utf ...
- Py修行路 python基础 (十二) 协程函数应用 列表生成式 生成器表达式
一.知识点整理: 1.可迭代的:对象下有_iter_方法的都是可迭代的对象 迭代器:对象._iter_()得到的结果就是迭代器 迭代器的特性: 迭代器._next_() 取下一个值 优点: 1.提供了 ...
- python 基础 列表生成式 生成器
列表生成式 列表生成式即List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式 举个例子,要生成list [1, 2, 3, 4, 5, 6, 7, ...
- Python学习 Day 4 函数 切片 迭代 列表生成式 生成器
定义函数 def my_abs(x):#求绝对值的my_abs函数 if x >= 0: return x else: return –x def nop():#空函数 pass#占位符 参数检 ...
随机推荐
- linux如何复制文件
目录 一:复制文件 二:文件详细属性 一:复制文件 copy的缩写cp. 格式: cp [参数] [被复制文件的路径] [复制到的新路径] 参数: -r : 递归复制 -a : 保证某些属性不变 案列 ...
- python08day
内容回顾 数据类型的补充 str:pass tuple: (1)----->int count 计数 index 通过元组获取索引 list sort 排序从小到大 sort(reverse=T ...
- 在ajax请求中,contentType 和 dataType 的区别?
一.在ajax请求中,contentType 和 dataType 的区别? 1.contentType 内容类型. 1.1默认是 "application/x-www-form-urlen ...
- AQS源码一窥-JUC系列
AQS源码一窥 考虑到AQS的代码量较大,涉及信息量也较多,计划是先使用较常用的ReentrantLock使用代码对AQS源码进行一个分析,一窥内部实现,然后再全面分析完AQS,最后把以它为基础的同步 ...
- HTML图片轮播
一.纯 CSS 实现图片轮播 引自原文作者:南张人 原文链接:https://blog.csdn.net/u011848617/article/details/80468463 理论基础 CSS3 a ...
- php表单初始化
转载请注明来源:https://www.cnblogs.com/hookjc/ //初始化表单值的函数function InitForm($row,$form="form1"){ ...
- iOS应用性能调优--初级---王朋
目录 我要给出的建议将分为三个不同的等级: 入门级. 中级和进阶级: 入门级(这是些你一定会经常用在你app开发中的建议) 1. 用ARC管理内存 2. 在正确的地方使用reuseIdentifier ...
- Docker部署lnmp 实战 (多注意配置文件,不管访问试试换个浏览器)
Docker部署LNMP环境 关闭防火墙,设置自定义网络 systemctl stop firewalld systemctl disable firewalld setenforce 0 docke ...
- NoSQL之Redis配置与优化
NoSQL之Redis配置与优化 目录 NoSQL之Redis配置与优化 一.关系数据库和非关系数据库 1. 关系型数据库 2. 非关系型数据库 3. 非关系型数据库产生背景 4. 关系型数据库和非关 ...
- Nginx中的Location和Rewrite
Nginx中的Location和Rewrite 目录 Nginx中的Location和Rewrite 一.location 1. location的分类 2. location常用的匹配规则 3. l ...