迭代器:

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. Nginx+keepalived 双机热备(主主模式)

    之前已经介绍了Nginx+Keepalived双机热备的主从模式,今天在此基础上说下主主模式的配置. 由之前的配置信息可知:master机器(master-node):103.110.98.14/19 ...

  2. 个人作业-Week1(新增详细说明)

    快速看完整部教材,列出你仍然不懂的5到10个问题,发布在你的个人博客上. 如何提出有价值的问题? 请看这个文章:http://www.cnblogs.com/rocedu/p/5167941.html ...

  3. 一些调格式的经验 & 插入图注和尾注

    一些调格式的经验(以Word2010为例) 1. 从目录正文分别编页码 将光标放在要重新编写页码起始页的最开始位置 分节:页面布局->分隔符->分节符(连续) 插入页码后,选中页码起始页页 ...

  4. 我的集合学习笔记--LinkedList

    一,Node节点: /** * 存储元素基本单位 */ public class Node { Object data; Node pre; Node next; public Node(Node p ...

  5. PAT 1011 A+B和C

    https://pintia.cn/problem-sets/994805260223102976/problems/994805312417021952 给定区间[-2^31^, 2^31^]内的3 ...

  6. java collections - keyset() vs entrySet() in map

    https://stackoverflow.com/questions/8962459/java-collections-keyset-vs-entryset-in-map http://blog.c ...

  7. JavaScript(ECMAScript) with 语句

    有同事,爱尝鲜,JavaScript ECMAScript with 语句,找了半天不知道局部变量的出处,原来是with语句搞得鬼. http://www.w3school.com.cn/js/pro ...

  8. [转帖]super-inspire

    quickStart/快速开始 访问临时服务器地址, 你可以在这里选择一个喜欢的系统, 然后系统将自动创建该系统的容器, 并自动打开新的网页进入 web shell 交互. 目前支持 Ubuntu14 ...

  9. linux bin & sbin different

    linux bin & sbin different flutter & $PATH http://blog.taylormcgann.com/2014/04/11/differenc ...

  10. 【转】SpringMVC,获取request的几种方法,及线程安全性

    作者丨编程迷思 https://www.cnblogs.com/kismetv/p/8757260.html 概述 在使用Spring MVC开发Web系统时,经常需要在处理请求时使用request对 ...