1、可迭代对象

迭代:将某个数据集内的数据“一个挨着一个的取出来”
可迭代协议:可以被迭代要满足的要求,即内部含有__iter__()方法
可迭代的类型:字符串、列表、元组、字典、集合
特点:惰性运算 #我们可以用dir()来查看是否还有__iter__()方法
have_iter = '__iter__' in dir([1,2])
#如果有,则have_iter = True

2、迭代器、__next__()

当我们调用可迭代对象的__iter__方法的时候,会返回一个例如list_iterator的类型,就是一个迭代器

迭代器协议:必须拥有__iter__方法和__next__方法

l = [1,2,3,4]
l_iter = l.__iter()__ #获得了迭代器
ret1 = l_iter.__next__() #获得第一个元素
ret2 = l_iter.__next__() #获得第二个元素 for循环就是这样进行迭代的

3、生成器、yield

Python中提供的生成器:
1.生成器函数:常规函数定义,但是,使用yield语句而不是return语句返回结果。 2.生成器表达式:类似于列表推导,但是,生成器返回按需产生结果的一个对象,而不是一次构建一个结果列表 #yield
yield语句一次返回一个结果,在每个结果中间,挂起函数的状态,以便下次重它离开的地方继续执行。通过调用__next__()和send()可以使生成器继续执行到下一个yield,不同的是send会传一个值给上一个yield

4、生成器函数

#例子:生成500万个hsr
def generate_hsr():
for i in range(5000000):
yield 'hsr' g = generate_hsr()
for i in g:
print(i)

5、send

#send获取下一个值,传值给上一个yield
#第一次使用生成器用next
最后一个yield不能接受传值
def generator():
print(123)
content = yield 1
print(content)
yield 2 g = generator()
ret1 = g.__next__() #ret1 =1
ret2 = g.send('hsr') #输出hsr 并 ret2 = 2

6、计算移动平均值

def avg_generator():
sum = 0
count = 0
avg = 0
while 1:
num = yield avg
count += 1
sum += num
avg = sum / count g = avg_generator()
r = g.__next__()
print(r)
for i in range(5):
ret = g.send(int(input()))
print(ret)

6、预激协程的装饰器

# 用装饰器进行一次next,后面就可以直接使用
def init(func):
def inner(*args,**kwargs):
g = func(*args,**kwargs)
g.__next__()
return g
return inner
@init
def avg_generator():
sum = 0
avg = 0
count = 0
while 1:
num = yield avg
count += 1
sum += num
avg = sum / count
g = avg_generator()
print(g.send(10))
print(g.send(15))
print(g.send(20))

7、yield from

#可以从容器中直接一个一个返回值
def generator():
l = [1,2,3,4,5]
yield from l g = generator()
for i in g:
print(i) #结果
1
2
3
4
5

9、列表推导式

#形式
#[满足条件的元素 for 元素 in 可迭代对象 if 条件] li = [i for i in range(31) if i % 3 == 0]
#得到30内可以被3整除的数的列表 #嵌套
li2 = [[1,2,3,4,5],[6,7,8,9,10]]
ret = [i for ls in li2 for i in ls if i %2 == 0]
#得到嵌套列表中可以被2整除的数的列表

10、生成器表达式

#和列表推导式类似,将[]换成()
#不同的是生成器表达式得到的是一个迭代器,而不是全部的数据 g = (i for i in range(10))
print(g) #会得到类似<generator object generator ...> #可以使用for循环获取值
for i in g:
print(i)

11、字典推导式

#以将键值对换为例(注意值要是不可迭代对象)

dic = {'a':10,'b':20}

dic_frequency = {dic[k]:k for k in dic}

12、集合推导式

#和列表推导式类似,将[]换成{},结果会去重

squared = { x**2 for i in [1,-1,2]}
#结果 squared = {1,4}

python基础9 (迭代器、生成器)的更多相关文章

  1. python基础6 迭代器 生成器

    可迭代的:内部含有__iter__方法的数据类型叫可迭代的,也叫迭代对象实现了迭代协议的对象 运用dir()方法来测试一个数据类型是不是可迭代的的. 迭代器协议是指:对象需要提供next方法,它要么返 ...

  2. python基础(9)-迭代器&生成器函数&生成器进阶&推导式

    迭代器 可迭代协议和迭代器协议 可迭代协议 只要含有__iter__方法的对象都是可迭代的 迭代器协议 内部含有__next__和__iter__方法的就是迭代器 关系 1.可以被for循环的都是可迭 ...

  3. (转)python基础之迭代器协议和生成器(一)

    一 递归和迭代 二 什么是迭代器协议 1.迭代器协议是指:对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个StopIteration异常,以终止迭代 (只能往后走不能往前 ...

  4. Python基础(冒泡、生成器、迭代器、列表与字典解析)

    一.冒泡算法 冒泡算法,给定一组数据,从大到小排序或者从小到大排序,就像气泡一样 原理:  相邻的两个对象相比,大的放到后面,交换位置 交换位置通过a,b=b,a来实现 1.我们可以通过for循环来根 ...

  5. Python基础之迭代器和生成器

    阅读目录 楔子 python中的for循环 可迭代协议 迭代器协议 为什么要有for循环 初识生成器 生成器函数 列表推导式和生成器表达式 本章小结 生成器相关的面试题 返回顶部 楔子 假如我现在有一 ...

  6. python基础之 迭代器回顾,生成器,推导式

    1.迭代器回顾 可迭代对象:Iterable 可以直接作用于for循环的对象统称为可迭代对象:Iterable.因为可迭代对象里面存在可迭代协议,所以才会被迭代 可迭代对象包括: 列表(list) 元 ...

  7. 7th,Python基础4——迭代器、生成器、装饰器、Json&pickle数据序列化、软件目录结构规范

    1.列表生成式,迭代器&生成器 要求把列表[0,1,2,3,4,5,6,7,8,9]里面的每个值都加1,如何实现? 匿名函数实现: a = map(lambda x:x+1, a) for i ...

  8. python基础之迭代器协议和生成器

    迭代器和生成器补充:http://www.cnblogs.com/luchuangao/p/6847081.html 一 递归和迭代 略 二 什么是迭代器协议 1.迭代器协议是指:对象必须提供一个ne ...

  9. python基础8 -----迭代器和生成器

    迭代器和生成器 一.迭代器 1.迭代器协议指的是对象必须提供一个next方法,执行该方法要么返回迭代中的下一项,要么就引起一个StopIteration异常,以终止迭代 (只能往后走不能往前退) 2. ...

  10. Python基础4 迭代器,生成器,装饰器,Json和pickle 数据序列化

    本节内容 迭代器&生成器 装饰器 Json & pickle 数据序列化 软件目录结构规范 作业:ATM项目开发 1.列表生成式,迭代器&生成器 列表生成式 孩子,我现在有个需 ...

随机推荐

  1. 7、A Design of Group Recommendation Mechanism Considering Opportunity Cost and Personal Activity Using Spark Framework---使用Spark框架的基于机会成本以及个人活动群组推荐机制

    来源EDB2018---EDB 一.摘要: 组推荐是将一种项目(例如产品.服务)推荐给由多个成员组成的组的方法. 最小痛苦法(least Misery)是一种具有代表性的群体推荐方法,其能够推荐考虑群 ...

  2. java中内存溢出和内存泄漏的区别

    虽然在java中我们不用关心内存的释放, 垃圾回收机制帮助我们回收不需要的对象,但实际上不正当的操作也会产生内存问题:如,内存溢出.内存泄漏 内存溢出:out of memory:简单通俗理解就是内存 ...

  3. HDU 5421 Victor and String (回文自动机)

    题目大意:让你维护一个字符串,支持在开头结尾插入字符,以及查询本质不同的回文串数量以及回文串总数量 开头结尾都维护一个$last$指针,如果插入新字符后,整个串是一个回文串,就把另一个$last$赋值 ...

  4. 模板 NTT 快速数论变换

    NTT裸模板,没什么好解释的 这种高深算法其实也没那么必要知道原理 #include <cstdio> #include <cstring> #include <algo ...

  5. 基于nginx的静态网页部署

    背景: 一序列的html网页需要部署 基于nginx的部署: 本文采用的基于openresty的nginx 配置. 简单地配置 Nginx 的配置文件,以便在启动 Nginx 时去启用这些配置即可实现 ...

  6. SQL SERVER-约束

    NOT NULL - 指示某列不能存储 NULL 值. UNIQUE - 保证某列的每行必须有唯一的值. PRIMARY KEY - NOT NULL 和 UNIQUE 的结合.确保某列(或两个列多个 ...

  7. angular-Then的用法

    then怎么使用(主要是如何从中提取出我们需要的后台返回的数据):then(fn) 方法中带一个参数,这个参数就是要被执行的函数,并且,这个作为参数的函数本身有一个参数,这个参数就是我们需要的数据,这 ...

  8. Educational Codeforces Round 6 C. Pearls in a Row set

    C. Pearls in a Row There are n pearls in a row. Let's enumerate them with integers from 1 to n from ...

  9. 50个Android开发技巧(12 为控件加入圆角边框)

    控件的圆角边框能够使你的App看起来更美观,事实上实现起来也非常easy. (原文地址:http://blog.csdn.net/vector_yi/article/details/24463025) ...

  10. [codeforces 894 E] Ralph and Mushrooms 解题报告 (SCC+拓扑排序+DP)

    题目链接:http://codeforces.com/problemset/problem/894/E 题目大意: $n$个点$m$条边的有向图,每条边有一个权值,可以重复走. 第$i$次走过某条边权 ...