迭代器:

l = [1, 2, 3, 4]
iter = l.__iter__()
print(iter)
print(iter.__next__())
print(iter.__next__())
print(iter.__next__())
print(iter.__next__())
'''
<list_iterator object at 0x0217A230>
1
2
3
4
'''

生成器:这种数据类型自动实现了迭代器协议,其他数据类型要调用内部的iter方法,

所以生成器就是可迭代对象

python中有两种方式提供生成器

1.生成器函数:用yield代替return函数返回,yield

一次返回一个结果,在每个结果中间挂起函数状态,

以便下一次从它离开的地方继续执行

2.生成器表达式:类似于列表推导,但是,生成器返回按需

产生的一个对象,而不是一次构建一个结果列表

def test():
yield 1
yield 2
iter = test()
print(iter)
print(iter.__next__())
print(iter.__next__())
'''
<generator object test at 0x01E96BF0>
1
2
'''
# yield 可以让函数一步一步地执行

def run():
print('runnig_1')
yield 1
print('runnig_2')
yield 2
print('runnig_3')
yield 3
print('runnig_4')
yield 4 it = run()
next(it)
print('可以做一些其他的事情...')
next(it) # 再接着执行
next(it)
next(it) '''
runnig_1
可以做一些其他的事情...
runnig_2
runnig_3
runnig_4
'''

三元表达式:

name  = ‘alex’

res = ‘SB’ if name ==‘alex’ else  ‘shuaige’

列表解析

l = []
for i in range(10):
l.append(i)
print(l) # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] # 使用列表解析
l = ['第%s' %i for i in range(10)]
print(l) # ['第0', '第1', '第2', '第3', '第4', '第5', '第6', '第7', '第8', '第9']
# 加三元表达式,没有四元表达式
l1 = ['第%s' %i for i in range(10) if i > 5]
print(l1) # ['第6', '第7', '第8', '第9']

列表解析可以很方便的生成列表,但是当数据比较大时会占很大的内存,这时候使用生成器表达式就可以避免内存占用过大这个问题

生成器的第二种方式:

l = ('第%s' %i for i in range(10))
print(l.__iter__()) # <generator object <genexpr> at 0x02146C70>
print(l.__iter__().__next__())
print(l.__iter__().__next__())
print(next(l))
print(next(l))
print(next(l))
print(next(l))
print(next(l))
print(next(l))
print(next(l))
print(next(l))
print(next(l)) #   最后抛出异常
'''
<generator object <genexpr> at 0x015E6C70>
第0
第1
第2
第3
第4
第5
第6
第7
第8
第9
Traceback (most recent call last):
File "F:/Python3/demo1.py", line 165, in <module>
print(next(l))
StopIteration
'''
内置函数sum也是基于迭代器协议
print(sum( (1,2,3,4) ))
 
# 内置函数sum也是基于迭代器协议
l = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
print(sum(x**2 for x in l))
print(sum( range(1000000) ))
print(sum(i for i in range(1000000) ))

迭代器_iter_,生成器yeild,三元运算,列表解析(十三)的更多相关文章

  1. python迭代器 生成器 三元运算 列表解析

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

  2. python的迭代器、生成器、三元运算、列表解析、生成器表达式

    一 迭代的概念 迭代是Python最强大的功能之一,是访问集合元素的一种方式. 迭代器是一个可以记住遍历的位置的对象. 迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前 ...

  3. day13 生成器 三元运算 列表解析

    本质上来说生成器迭代器都是一种数据类型,如果你直接打印生成器是无法得出值的,会得到一串内存地址,即一个对象想要得到生成器的值必须要用for或者next,list等来获取 生成器生成器就是一个可迭代对象 ...

  4. Python开发——函数【迭代器、生成器、三元表达式、列表解析】

    递归和迭代 小明问路篇解释说明 递归:小明——>小红——>小于——>小东:小东——>小于——>小红——>小明 小明向小红问路,因小红不知道,所以向小于问路,因小于不 ...

  5. python迭代器和生成器(3元运算,列表生成式,生成器表达式,生成器函数)

    1.1迭代器 什么是迭代器: 迭代器是一个可以记住遍历的位置对象 迭代器对象从集合的第一个元素元素开始访问,直到所有元素被访问完结束,迭代器只能往前不会后退. 迭代器有两个基本方法:iter ,nex ...

  6. Python自动化运维之7、生成器、迭代器、列表解析、迭代器表达式

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

  7. 3、Python迭代器、列表解析及生成器(0530)

    1.动态语言 sys.getrefcount()    //查看对象的引用计数 增加对象的引用计数场景 对象创建时:以赋值的方式,创建变量名的同时就会创建变量 将对象添加进容器时:类似list.app ...

  8. Python编程笔记(第三篇)【补充】三元运算、文件处理、检测文件编码、递归、斐波那契数列、名称空间、作用域、生成器

    一.三元运算 三元运算又称三目运算,是对简单的条件语句的简写,如: 简单条件处理: if 条件成立: val = 1 else: val = 2 改成三元运算 val = 1 if 条件成立 else ...

  9. Python 迭代器和列表解析

    Python 迭代器和列表解析 1)迭代器 一种特殊的数据结构,以对象形式存在 >>> i1 = l1.__iter__() >>> i1 = iter(l1) 可 ...

  10. 文件处理,三元操作符,seek()函数,迭代函数和列表解析,reduce函数

    1.文件读取方类型 r,r+,w,x,a, r,读文件 w,写文件,文件内容全部删除,并将新内容从第一行开始赋值 x,写文件,只有文件不存在,可写,文件存在,报错 a,在文件莫问追加信息 r+,w+, ...

随机推荐

  1. vs2017+opencv4.0.1安装配置详解(win10)

    一.说明 笔者之前已经安装过了vs2017,对应的opencv是3.4.0版本的.但现在想体验下opencv4的改变之处,所以下载了最新的opencv4.0.1. vs2017的安装请自行搜索安装,本 ...

  2. Docker容器学习梳理 - 容器时间跟宿主机时间同步

    在Docker容器创建好之后,可能会发现容器时间跟宿主机时间不一致,这就需要同步它们的时间,让容器时间跟宿主机时间保持一致.如下: 宿主机时间 [root@slave-1 ~]# date Fri M ...

  3. 项目开发之package.json

    Name 必须字段. 提示: 不要在name中包含js, node字样: 这个名字不能以点号或下划线开头: 这个名字不能包含有大写字母: 这个名字可能在require()方法中被调用,所以应该尽可能短 ...

  4. 移动端触摸(touch)事件

    移动端时代已经到来,作为前端开发的我们没有理由也不应该坐井观天,而是勇敢地跳出心里的那口井,去拥抱蔚蓝的天空.该来的总会来,我们要做的就是接受未知的挑战.正如你所看到的,这是一篇关于移动端触摸事件的文 ...

  5. C. Maximum Subrectangle

    链接 [http://codeforces.com/contest/1060/problem/C] 题意 给你两个数列,可以构成一个矩阵C,ci,j=ai⋅bj 1≤x1≤x2≤n , 1≤y1≤y2 ...

  6. 11.18 Daily Scrum

    这两天开发人员陆续提交了自己开发的部分. 目前所有开发任务都已经完成,剩下的只是测试和整合,做最后的冲刺. 明天的任务: 李承晗:测试与整合

  7. [Beta阶段]展示博客

    一.团队成员简介与个人博客地址 团队博客地址:http://www.cnblogs.com/wowotoubuaa/ 江昊,项目经理http://www.cnblogs.com/haoj/ 王开,后端 ...

  8. HDU 2024 C语言合法标识符

    http://acm.hdu.edu.cn/showproblem.php?pid=2024 Problem Description 输入一个字符串,判断其是否是C的合法标识符.   Input 输入 ...

  9. [转帖]龙芯下一代处理器微结构GS464E细节曝光

    龙芯下一代处理器微结构GS464E细节曝光 [日期:2015-05-26] 来源:Linux公社  作者:Linux [字体:大 中 小] http://www.linuxidc.com/Linux/ ...

  10. QA

    QA:Quality Assurance,品质保证 IDQA:Individual Document Quality Assurance 设计品质保证 QE:Quantitative Easing 质 ...