【python】 迭代器、生成器、列表推导式
一、可迭代对象、迭代器
1、可以被for循环的数据类型(可迭代对象):
字符串(str)、列表(list)、字典(dict)、元祖(tuple)、range()
2、迭代器
2.1 将可迭代对象==>迭代器(__iter__())
st = 'abc' # 可迭代对象
st_iter = st.__iter__() # 迭代器
print(st_iter) # 返回 :<str_iterator object at 0x00000117E93A2F98>
2.2 将可迭代对象==>迭代器(iter(可迭代对象))
st = 'abc'
st_iter = iter(st)
print(st_iter)
# 返回 :<str_iterator object at 0x00000117E93A2F98>
2.3 迭代器取值(__next__())
# 1、调用函数内的方法去取值 st = 'abc'
st_iter = st.__iter__()
print(st_iter.__next__()) # 迭代器每次只取一次数据,取完一次后指针停留在当前位置,便于下次接着取值
print(st_iter.__next__())
print(st_iter.__next__()) # 返回:
a
b
c
2.4 迭代器取值(next(迭代器))
2、调用函数去取值 st = 'abc'
st_iter = st.__iter__()
print(next(st_iter))
print(next(st_iter))
print(next(st_iter))
# 返回:
a
b
c
3、可迭代对象与迭代器的区别:
1) 可迭代对象可以转换成迭代器,迭代器不能逆转;
2)可迭代对象的方法:__iter__()
迭代器的方法:__iter__()、__next__()
4、判断 可迭代对象(Iterable) 和 迭代器(Iterator) 的两种方法:
4.1 方法一:
判断对象是否有"__iter__"方法
如果有,返回True,是可迭代对象
st = 'abc'
print("__iter__" in dir(st)) # dir(o):显示所有的方法
返回:
True
4.2 方法二:
用isinstance()方法判断:
from collections import Iterable
from collections import Iterator
# 判断是否为可迭代对象,返回True
print(isinstance(st,Iterable))
# 判断是否为迭代器,返回True
print(isinstance(st.__iter__(),Iterator)) 控制台报错:
DeprecationWarning: Using or importing the ABCs from 'collections' instead of from 'collections.abc' is deprecated,
and in 3.8 it will stop working # 注:有报错没关系,是因为版本的原因(3.7.3)
5、迭代器的意义:
节省内存
迭代器有惰性机制(每次只取一次数据)
不能反复,一直往下执行(如:有100条数据,第一次循环,执行5条数据,第二次循环,从第6条开始执行)
6、for循环的机制(for循环会自动生成迭代器)
for循环中内部含有__iter__方法会自动将可迭代对象转换成迭代器;
再调用__next__方法
有异常处理机制(打印next方法,会一直循环可迭代对象,当循环结束,打印next方法就会报错,所以报错的时候加上异常处理)
7、用迭代器实现for循环
list = [1,2,3,4]
# 1、先判断list是否是可迭代对象
if '__iter__' in dir(list):
# 2、转化成迭代器
list_iter = list.__iter__()
# 3、将迭代器里面的值依次取出并打印
while True:
try:
print(list_iter.__next__())
except StopIteration as e:
print("--- 打印完毕!---%s"%e)
break
else:
print("不是可迭代对象")
二、生成器
生成器的本质就是迭代器(所以自带__iter__() 和 __next__() 方法)
1、迭代器构建的三种方式:
- 可以用生成器函数
- 可以用各种推导式构建函数
- 可以通过数据转换
2、生成器函数(yield=>函数返回值)
def gener():
print(111)
yield 'aaa'
print(222)
yield 'bbb'
print(333)
g = gener()
print(g) # 打印生成器函数
print(g.__next__()) # 打印第一个返回值
print(g.__next__()) # 打印第二个返回值 返回:
<generator object gener at 0x000001EF1CDF0570>
111
aaa
222
bbb
3、return 和 yield 的区别
1) return : 返回值给调用者,并结束此函数
2)yield : 返回值给调用者,并将指针停留在当前位置
4、send
def gener():
print(111)
yield "aaa"
print(222)
ret = yield ("bbb")
print("----->",ret)
print(333)
yield "ccc"
print(444)
g = gener()
print(g)
print(g.__next__())
print(g.send(None))
print(g.send("BBB")) ## 给上一个 yield 赋值 返回:
<generator object gener at 0x000002BE42060570>
111
aaa
222
bbb
-----> BBB
333
ccc
5、send 与 __next__ 的区别
相同点:都是取迭代器里面的值
不同点: 1)send是给上一个yield赋值
2)send不能给第一个、最后一个yield赋值
三、列表推导式
1、列表推导式语法:
# 1.1 循环模式
l1 = [变量(或者加工后的变量) for 变量 in 可迭代数据类型] print(l1)
# 1.2 筛选模式
l1 = [变量(或者加工后的变量) for 变量 in 可迭代数据类型 if 条件]
print(l1)
2、生成器表达式语法(小括弧啊里面有类型列表推导式的都是生成器)
l2 = (变量(或者加工后的变量) for 变量 in 可迭代数据类型)
# 打印生成器
print(l2)
# 取值
for i in l2:
print(i)
3、实例
3.1 列表推导式
例一:30以内所有能被3整除的数
st = [i for i in range(31) if i % 3 ==0]
print(st)
例二:30以内所有能被3整除的数的平方
st = [i*i for i in range(31) if i % 3 ==0]
print(st)
例三:找到嵌套列表中名字含有两个“e”的所在名字
names = [['Tom','Billy','Jefferson','Andrew','Weseiy','Steven','Joe'],
['Alince','Jill','Ana','Wendy','Jennifer','sherry','Eva']]
ee_name = [ j for i in names for j in i if j.count('e') == 2 ]
print(ee_name)
3.2 字典推导式
例一:将一个字典的key和value对调
dict = {'a':1,'b':2}
new_dict = {dict[k]:k for k in dict}
print(new_dict)
例二:合并大小写对应的value值,将k统一成小写
dict = {'a':10,'b':34,'A':7,'z':3}
new_dict = {k.lower():dict.get(k.lower(),0)+dict.get(k.upper(),0)for k in dict.keys()}
print(new_dict)
3.3 集合推导式
例一:计算列表中每个值得平方,自带去重功能
set = {i**2 for i in [1,-1,2]}
print(set)
【python】 迭代器、生成器、列表推导式的更多相关文章
- python 迭代器,生成器与推导式
函数的动态传参 *args 动态接收所有位置参数 **kwargs 动态接收关键字参数 顺序: 位置参数, *args, 默认参数, **kwargs def func(*args, **kwargs ...
- Python之路----列表推导式和生成器的表达式
列表推导式 egg_list=['鸡蛋%s'%i for i in range(10)] print(egg_list) 列表推导式 推导过程 egg_list = [] for i in range ...
- python 三元表达式 列表推导式,生成器表达式。递归,匿名函数, 内置函数
三元表达式 三元表达式仅应用于: 1.条件成立返回一个值 2.条件不成立返回一个值 res = x if x>y else y print(res) name= input("姓名&g ...
- python基础17_列表推导式 vs 生成器表达式
[ ] 列表推导式,是用简单的语法来生成列表, ( ) 生成器表达式,是用简单的语法创建个生成器. 外观上仅括号不一样. 虽然写起来方便,但是读起来稍显费力,另外,不易调试. # 列表推导式 prin ...
- Python中的列表推导式
Python里面有个很棒的语法糖(syntactic sugar),它就是 list comprehension ,有人把它翻译成“列表推导式”,也有人翻译成“列表解析式”.名字听上去很难理解,但是看 ...
- python中的列表推导式——轻量级循环
列表推导式(list comprehension)是利用其他列表创建新列表(类似于数学术语中的集合推导式)的一种方法.它的工作方式类似于for循环,也很简单. 列表推导式书写形式: [表达式 for ...
- python基础之列表推导式
#列表推导式 ---> 返回的是列表 for语句 效率更高# 1*1 2*2 3*3 4*4 5*5 6*6 7*7 8*8 9*9# import time# to = time.clock( ...
- Python List comprehension列表推导式
http://blog.chinaunix.net/uid-28631822-id-3488324.html 具体内容需要进一步学习
- Python 速通爆肝、列表推导式、生成器、装饰器、生命游戏
列表推导式.赋值.切片(替换.插入).字符串处理与判断.enumerate().格式化字符串.读写文件.global 关键字.字符串startswith().类与对象.生成器.装饰器.Self.*ar ...
- python高级编程之列表推导式
1. 一个简单的例子 在Python中,如果我们想修改列表中所有元素的值,可以使用 for 循环语句来实现. 例如,将一个列表中的每个元素都替换为它的平方: >>> L = [1, ...
随机推荐
- 【托业】【怪兽】TEST02
★ overturn v.推翻 ★ disciplinary adj.纪律的; 训练的; 惩罚的; ★disciplined 有纪律的 ★discipline v.纪律 ★outlook 态度 ★pe ...
- php json 中文不转义 & 转义为中文
JSON_UNESCAPED_UNICODE private function decodeUnicode($str){ return preg_replace_callback('/\\\\u([0 ...
- 数据结构 - 表插入排序 具体解释 及 代码(C++)
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/u012515223/article/details/24323125 表插入排序 具体解释 及 代码 ...
- 支持Linux系统的加密狗
深思数盾 https://www.sense.com.cn/ 产品:精锐5 版本:标准版.精灵版.IE版.时钟锁 快速实现高安全度的软件保护,轻松定义多种授权模式1.防止软件盗版,防止逆向工程 通过增 ...
- nginx隐藏tp路由index.php
---------------------------------------------- 也可以找到vhosts.conf文件修改, 重启nginx,service nginx restart
- visual studio 启动报 activityLog.xml文件 错误
1.在安装目录里面找到 devenv.exe 这个文件的所在位置C:\Program Files\Microsoft Visual Studio 10.0\Common7\IDE 2.点击左下角图标, ...
- ELK日志分析解决方案
概要 ELK(Elasticsearch , Logstash, Kibana的简称)是目前比较流行的日志分析解决方案,核心包括了三个部分 Elasticsearch:日志查询分析引擎 Logstas ...
- debian9升级安装到python3.6和pip3.6
安装步骤 1.添加testing源 vim /etc/apt/sources.list deb http://mirrors.163.com/debian/ testing main 2.更新源 ap ...
- 转:select2 使用教程(简)
用了这么久的Select2插件,也该写篇文章总结总结.当初感觉Select2不是特别好用,但又找不到比它更好的下拉框插件. 在我的印象里Select2有2个版本,最新版本有一些新的特性,并且更新了一下 ...
- 在C#中GUID生成的四种格式
var uuid = Guid.NewGuid().ToString(); // 9af7f46a-ea52-4aa3-b8c3-9fd484c2af12 var uuidN = Guid.NewGu ...