15.迭代器:工具

1.可迭代对象:

​ 官方声明,只要具有__iter__方法的就是可迭代对象

list,dict,str,set,tuple -- 可迭代对象,使用灵活

#方法一:
list.__iter__()
dict.__iter__() #方法二:
查看源代码 #方法三:
print(dir(list))
#官方声明,只要具有__iter__方法的就是可迭代对象
2.迭代器:

官方声明:只要具有__iter__方法__next__方法就是迭代器

f = open("",'w')
f.__iter__()
f.__next__()

将可迭代对象,转换成迭代器

lst = [1,2,3,4,6]
new_lst = lst.__iter__()#将可迭代对象,转换成迭代器 new_lst.__iter__()
new_lst.__next__()
print(new_lst.__next__())#每次获取一个值,第一次获取第一个值,以后向后推 #自己写 for i in lst(): print(i)
lst = [1,2,3,4,6]
count = len(lst)
new_lst = lst.__iter__()
while count:
print(new_lst.__next__())
count -= 1
#for的本质
lst = [1,2,3,4,6]
new_lst = lst.__iter__()
while 1:
try:
print(new_lst.__next__())
except:
break
3.总结:

​ 可迭代对象:

​ 优点:使用灵活,可以直接查看值

​ 缺点:占内存,不能迭代值

​ 迭代器:

​ 优点:节省内存,惰性机制

​ 缺点:使用不灵活,操作较繁琐,不能直接查看元素

迭代器的特性:

  1. 一次性的(用完就没有了)
  2. 不能后退
  3. 惰性机制(节省内存)

可迭代对象:具有__iter__()方法的

可迭代器:具有__iter__()方法和__next__()方法的

迭代器的使用时机:当容器中数据量较多的时候使用迭代器

16.生成器:

迭代器:python中内置的一中节省空间的工具

生成器的本质就是一个迭代器

生成器与迭代器的区别:

​ 迭代器:python自带

​ 生成器:程序员写的

写一个生成器:

​ 将函数中的return改写成yield就是一个生成器,return和yield都是返回:

  1. return和yield都是返回
  2. return和yield都可以写多次
  3. return只执行一次,yield可执行多次
  4. 一个next对应一个yield,会记录停留的位置。超出会报错

g = func()#产生一个生成器

​ 生成器可以使用for循环取值

​ yield from -- 将可迭代对象的元素逐个返回

​ 在函数内部,yield能将for循环和while循环进行暂停

def func():
print(123)
yield "你好"
print(321)
yield "我好"
print(func())
#结果:<generator object func at 0x000001913911F0A0>
g = func()
g.__inter__()
print(g.__next__()) #会记录停留的位置
def func():
if 3 > 2:
yield "你好"
if 4 > 2:
yield "我好"
yield "大家好"
g = func()
print(g.__next__())
print(g.__next__())
print(g.__next__())
'''
结果:
你好
我好
大家好
''' #for 循环
for i in g:
print(i)

坑:会产生新的生成器

#每次都是新的生成器
print(foo().__next__())
print(foo().__next__())
#用赋值只产生一个生成器
g = foo()
def foo():
for i in range(10):
pass
yield i
count = 1
while 1:
yield count
count += 1
g = foo()
#print(next(g)) = print(g.__next__()) --推荐使用next(g)
print(next(g))
print(next(g))
print(next(g))
#next可以在while中停住
'''
结果:
9
1
2
'''

seed() -- 了解

#send()第一次只能传None,用于激活,否则会报错,以后可以传各种数据
def func():
a = yield "send激活"
print(a)
b = yield "send开始"
g = func()
print(g.send(None))
print(g.send(123))

生成器应有场景:

#当有大量的数据时
def func():
lst = []
for i in range(1000000):
lst.append(i)
return lst
print(func())
#生成器改进
def func():
for i in range(1000000):
yield i
g = func()
for i in range(50):
print(next(g))

yield from -- 将可迭代对象逐个返回

def func():
list1 = ["牛羊配","老奶奶花生米","卫龙","虾扯蛋","米老头","老干妈"]
yield from list1 #yield list1 会直接返回整个列表
g = func()
print(next(g))
print(next(g))
'''
结果:
牛羊配
老奶奶花生米
''' def func():
list1 = ["牛羊配","老奶奶花生米","卫龙","虾扯蛋","米老头","老干妈"]
lsit2 = ["小浣熊","老干爹","亲嘴烧","麻辣烫","黄焖鸡","井盖"]
yield from list1
yield from list2
g = func()
#将lsit1返回完,才会返回list2
print(next(g))
print(next(g))
print(next(g))

python函数知识四 迭代器、生成器的更多相关文章

  1. Python装饰器、迭代器&生成器、re正则表达式、字符串格式化

    Python装饰器.迭代器&生成器.re正则表达式.字符串格式化 本章内容: 装饰器 迭代器 & 生成器 re 正则表达式 字符串格式化 装饰器 装饰器是一个很著名的设计模式,经常被用 ...

  2. 初学 Python(十四)——生成器

    初学 Python(十四)--生成器 初学 Python,主要整理一些学习到的知识点,这次是生成器. # -*- coding:utf-8 -*- ''''' 生成式的作用: 减少内存占有,不用一次性 ...

  3. Python基础知识(四)

    Python基础知识(四) 一丶列表 定义格式: 是一个容器,由 [ ]表示,元素与元素之间用逗号隔开. 如:name=["张三","李四"] 作用: 存储任意 ...

  4. python基础知识7——迭代器,生成器,装饰器

    迭代器 1.迭代器 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退.另外,迭代器 ...

  5. python之 可迭代 迭代器 生成器

    0. 1.总结 (1) (a)iterable 可迭代(对象) 能力属性 指一个对象能够一次返回它的一个成员,for i in a_list 而不需要通过下标完成迭代. 例子包括所有序列类型(list ...

  6. python之路(八)-迭代器&生成器

    迭代器 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退.另外,迭代器的一大优点是 ...

  7. python函数知识

    一.三目运算 也叫三元运算,例如result=x if x<y else y 二.集合(set) 返回主页集合(set):把不同的元素组成一起形成集合,是python基本的数据类型.集合元素(s ...

  8. python学习笔记四 迭代器,生成器,装饰器(基础篇)

    迭代器 __iter__方法返回一个迭代器,它是具有__next__方法的对象.在调用__next__方法时,迭代器会返回它的下一个值,若__next__方法调用迭代器 没有值返回,就会引发一个Sto ...

  9. python学习笔记(5)--迭代器,生成器,装饰器,常用模块,序列化

    生成器 在Python中,一边循环一边计算的机制,称为生成器:generator. 如: >>> g = (x * x for xin range(10)) >>> ...

随机推荐

  1. C#高性能大容量SOCKET并发(四):缓存设计

    原文:C#高性能大容量SOCKET并发(四):缓存设计 在编写服务端大并发的应用程序,需要非常注意缓存设计,缓存的设计是一个折衷的结果,需要通过并发测试反复验证.有很多服务程序是在启动时申请足够的内存 ...

  2. Decision Tree

    Decision Tree builds classification or regression models in the form of a tree structure. It break d ...

  3. 简单封装 Delphi 的 DirectX类

    var CreatorRenderer  : TCreatorRenderer; Form1: TForm1; 窗体代码: {$R *.dfm} procedure TForm1.FormCreate ...

  4. ring3层一种占用文件的方法(DuplicateHandle以后,把占用文件的句柄丢给系统进程,导致被占用)

    前段时间,一个测试工程师问我关于怎样长时间的占用一个文件,而使别的程序无法再访问这个文件,想起以前很多病毒木马经常劫持hosts文件不放,除非你找到占用文件的程序,并强行结束掉,否则怎么也访问不了ho ...

  5. Flume NG高可用集群搭建详解

    .Flume NG简述 Flume NG是一个分布式,高可用,可靠的系统,它能将不同的海量数据收集,移动并存储到一个数据存储系统中.轻量,配置简单,适用于各种日志收集,并支持 Failover和负载均 ...

  6. Spark之json数据处理

    -- 默认情况下,SparkContext对象在spark-shell启动时用namesc初始化.使用以下命令创建SQLContext. val sqlcontext = new org.apache ...

  7. 分享五个404页面模板 超好看的404页面你的网站离不了 seo优化404

    一个完整的网站离不开一个好的404页面,404页面不光是让你的网站美观,它对SEO的作用也很大,你想一下如果用户打开你的网站,输入一个不存在的风址,如果没有404直接就报错了,有了404就能打开一个美 ...

  8. 【入门】WebRTC知识点概览 | 内有技术干货免费下载

    什么是WebRTC WebRTC 即Web Real-Time Communication(网页实时通信)的缩写,是一个支持网页浏览器之间进行实时数据传输(包括音频.视频.数据流)的技术.经过多年的发 ...

  9. linux下svn安装

    1.环境centos6.4 2.安装svnyum -y install subversion 3.配置 建立版本库目录mkdir /www/svndata svnserve -d -r /www/sv ...

  10. python算法与数据结构-队列(44)

    一.队列的介绍 队列的定义:队列是一种特殊的线性表,只允许在表的头部(front处)进行删除操作,在表的尾部(rear处)进行插入操作的线性数据结构,这种结构就叫做队列.进行插入操作的一端称为队尾,进 ...