Python之路-迭代器 生成器 推导式
迭代器
可迭代对象
print(list.__iter__([1,2,3])) print(dict.__iter__({1:2,3:4})) print(tuple.__iter__((1,2,3,4))) print(range.__iter__(range(10))) 运行结果 <list_iterator object at 0x0000023C28DE8710> <dict_keyiterator object at 0x0000023C28DC6868> <tuple_iterator object at 0x0000023C28DE8710> <range_iterator object at 0x00000109ABB3BF30>
迭代器
lst = [1,2,3,4] l1 = lst.__iter__() #转换成迭代器 print(l1.__next__()) #执行迭代器 print(l1.__next__()) print(l1.__next__()) print(l1.__next__()) 运行结果: 1 2 3 4
lst = [1,2,3,4] count = 0 l = lst.__iter__() while count < len(lst): print(l.__next__()) count += 1 运行结果: #这就是for循环的运行结果 1 2 3 4
lst = [1,2,3,4] l1 = lst.__iter__() #转换成迭代器 print(l1.__next__()) #执行迭代器 print(l1.__next__()) print(l1.__next__()) print(l1.__next__()) print(l1.__next__()) print(l1.__next__()) lst共有4个元素,当我在执行的时候多加了几个,它就会报错,那既然for循环也是这样的机制为啥它不报错呢?,这里用到一个知识点,叫捕捉错误 while True: try: lst = [1,2,3,4] l1 = lst.__iter__() #转换成迭代器 print(l1.__next__()) #执行迭代器 print(l1.__next__()) print(l1.__next__()) print(l1.__next__()) print(l1.__next__()) print(l1.__next__()) except StopIteration: #如果知道是什么类型的错误,可以添加 break
from collections import Iterable,Iterator lst = [1,2,3,4] print(isinstance(lst,Iterable)) print(isinstance(lst,Iterator)) print(isinstance(lst.__iter__(),Iterable)) print(isinstance(lst.__iter__(),Iterator)) print(isinstance({1:2,3:4,5:6},Iterable)) print(isinstance({1:2,3:4,5:6},Iterator)) 返回结果: True False True True True False
生成器
(结果 for 变量量 in 可迭代对象 if 条件筛选)
生成器的执行顺序
def func(): #第1步定义名称 print(1) #第5步 执行生成器 yield 4 #第6步 返回执行结果并打印出来,执行到这里停止 print(2)#第8步 执行生成器 yield 5 #第9步 返回结果并打印出来 g = func() #第2步,执行,当方向代码块中有yield时,识别为生成器, 执行第3步 g = func()赋给变量g print(g.__next__())#第4步第一次调用生成器 print(g.__next__())#第7步第二次调用生成器 运行结果: 1 4 2 5
def gen(): li = [] for i in range(10): yield i g = gen() print(g.__next__())#这样是不是很麻烦 print(g.__next__()) print(g.__next__()) print(g.__next__()) print(g.__next__()) print(g.__next__()) print(g.__next__()) print(g.__next__()) print(g.__next__()) print(g.__next__())
def gen(): li = [] for i in range(10): yield i g = gen() for i in range(10): print(g.__next__())#利用for 循环,很方便的执行
send()
def func(): print(44) l = yield 5 print(55) print(l) yield 3 g = func() print(g.__next__()) print(g.send('你好啊')) #相对于 __next__ + 赋值(既能执行下一步操作,又能把值带进去 打印结果: 1 4 2 5 44 5 55 你好啊 3 def gen(x): res = 0 for i in range(x): res = yield res ** 2 g = gen(5) g.send(None) print(g.send(1)) print(g.send(2)) print(g.send(3)) print(g.send(4))
生成器总结
推导式
列表推导式
li = [] for i in range(10): li.append(i) print(li) li = [i for i in range(10)] #列表推导式 print(li) 打印结果: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
列表筛选
li = [i for i in range(10)if i > 3] print(li) li = [i for i in range(10)if i % 2 == 0] print(li)
集合推导式
dic = {1:2,3:4} se = {i for i in dic.items()} print(se) 输出结果: {(1, 2), (3, 4)}
推导过程
dic = {1:2,3:4} se = set() for i in dic.items(): se.add(i) print(se) 打印结果: {(1, 2), (3, 4)}
字典推导式
lst = [1,3] lst1 = [2,4] dic = {lst[i]:lst1[i] for i in range(2)} print(dic) 输出结果: {1: 2, 3: 4}
推导过程
lst = [1,3] lst1 = [2,4] dic = {} for i in range(2): dic[lst[i]] = lst1[i] print(dic) 输出结果: {1: 2, 3: 4}
生成器推导式
l = (i for i in range(100)) for i in range(10): print(l.__next__())
推导过程
def func(): for i in range(10): yield i l = func() for i in range(10): print(l.__next__())
Python之路-迭代器 生成器 推导式的更多相关文章
- python之路---12 生成器 推导式
三十.函数进阶 1.生成器 函数中有yield 的就是生成器函数(替代了return) 本质就是迭代器 一个一个的创建对象 节省内存 ①创建生成器 最后以yield结束 ...
- 记录我的 python 学习历程-Day12 生成器/推导式/内置函数Ⅰ
一.生成器 初识生成器 生成器的本质就是迭代器,在python社区中,大多数时候都把迭代器和生成器是做同一个概念. 唯一的不同就是: 迭代器都是Python给你提供的已经写好的工具或者通过数据转化得来 ...
- python迭代器,生成器,推导式
可迭代对象 字面意思分析:可以重复的迭代的实实在在的东西. list,dict(keys(),values(),items()),tuple,str,set,range, 文件句柄(待定) 专业角度: ...
- 12.Python略有小成(生成器,推导式,内置函数,闭包)
Python(生成器,推导式,内置函数,闭包) 一.生成器初始 生成器的本质就是迭代器,python社区中认为生成器与迭代器是一种 生成器与迭代器的唯一区别,生成器是我们自己用python代码构建成的 ...
- Python进阶(四)----生成器、列表推导式、生成器推导式、匿名函数和内置函数
Python进阶(四)----生成器.列表推导式.生成器推导式.匿名函数和内置函数 一丶生成器 本质: 就是迭代器 生成器产生的方式: 1.生成器函数
- Python——生成器&推导式
生成器 生成器的本质就是迭代器,那么还为什么有生成器呢,两者唯一的不同就是迭代器都是Python给你提供能够的已经写好的工具或者通过数据转化得来的.而生成器是需要我们自己用Python代码构建的工具. ...
- Python函数04/生成器/推导式/内置函数
Python函数04/生成器/推导式/内置函数 目录 Python函数04/生成器/推导式/内置函数 内容大纲 1.生成器 2.推导式 3.内置函数(一) 4.今日总结 5.今日练习 内容大纲 1.生 ...
- Python之路迭代器协议、for循环机制、三元运算、列表解析式、生成器
Python之路迭代器协议.for循环机制.三元运算.列表解析式.生成器 一.迭代器协议 a迭代的含义 迭代器即迭代的工具,那什么是迭代呢? #迭代是一个重复的过程,每次重复即一次迭代,并且每次迭代的 ...
- python 列表推导式,生成器推导式,集合推导式,字典推导式简介
1.列表推导式multiples = [i for i in range(30) if i % 2 is 0]names = [[],[]]multiples = [name for lst in n ...
随机推荐
- Python/WSGI 应用快速入门--转
http://uwsgi-docs-cn.readthedocs.io/zh_CN/latest/WSGIquickstart.html 这个快速入门指南将会向你展示如何部署简单的 WSGI 应用和普 ...
- PHP中的文件操作
文件系统的概述 任何类型的变量在运行的时候都是将其加载到内存里面.但是内存有一个特点:CPU读取内存的速度很快,但是一旦断电,内存里面的数据就会消失.如果要持久的保存数据,有两种方法:将数据存储到 ...
- tomcat启动时自动运行代码
原文链接:http://jingpin.jikexueyuan.com/article/49660.html 作者: 一直向北 发布时间:2015-07-13 11:12:13 方法1:tomcat ...
- codeforces736D. Permutations(线性代数)
题意 $m \leqslant 500000$,题目打错了 Sol 神仙题Orz 构造矩阵$B$,使得$B[b[i]][a[i]] = 1$ 那么他的行列式的奇偶性也就对应了生成排列数列数量的奇偶性( ...
- 20170308web作业1
代码20170308001: <%@ page language="java" import="java.util.*" pageEncoding=&qu ...
- spring @RequestBody 和 @RequestParams 同时使用
@RequestBody 和 @RequestParams 是可以同时使用的. @RequestBody 接受的数据类型是 content-type:"application/json&qu ...
- uvm_sequence_item——sequence机制(一)
让子弹飞一会 UVM框架,将验证平台和激励分开,env以下属于平台部分,test和sequence属于激励,这样各司其职.我们可以将sequence_item 比喻成子弹,sequencer 类比成弹 ...
- uvm_transaction——事物
文件: src/base/uvm_transaction.svh 类: uvm_transaction uvm_transaction继承自uvm_object,添加了timing和record ...
- Memcache笔记01-Memcache的安装
memcached是什么? Memcached是一个高性能的分布式的内存对象缓存系统,目前全世界不少人使用这个缓存项目来构建自己大负载的网站,来分担数据库的压力,通过在内存里维护一个统一的巨大的has ...
- vue+element ui项目总结点(六)table编辑当前行、删除当前行、新增、合计操作
具体属性方法参考官方网站:http://element-cn.eleme.io/#/zh-CN/component/installation <template> <div clas ...