目录


一、迭代器

1.迭代器的概念理解

  1. '''
  2. 迭代器从字面上理解就是迭代的工具。而迭代是每次的开始都是基于上一次的结果,不是周而复始的,而是不断发展的。
  3. '''
  4. l=[1,2,3,4]
  5.  
  6. count=0
  7. while count<len(l):
  8. print(l[count])
  9. count+=1

2.可迭代对象与迭代器对象

  1. '''
  2. (1)可迭代对象:
  3. 可迭代对象就是内置__iter__方法的对象(再次重申,python中一切皆对象)。
  4. (2)迭代器对象就是内置有__iter__方法和__next__方法的对象。
  5.  
  6. 可迭代对象执行了obj.__iter__()得到的结果就是迭代器对象,迭代器对象执行了obj.__iter__()得到的是迭代器本身。
  7.  
  8. 要明确的一点是迭代器对象一定是可迭代对象,但是可迭代对象不一定是迭代器对象。
  9. '''
  1. #字符串
  2. string='hello world'
  3. iter_st=string.__iter__()
  4. while True:
  5. try:
  6. print(iter_st.__next__())
  7. except StopIteration:
  8. break
  9.  
  10. #列表
  11. s=[1,3,4,5,'a']
  12. iter_s=s.__iter__()
  13. while True:
  14. try:
  15. print(iter_s.__next__())
  16. except StopIteration:
  17. break
  18.  
  19. #字典
  20. dic={'a':1,'b':2}
  21. iter_dic=dic.__iter__()
  22. while True:
  23. try:
  24. print(iter_dic.__next__())
  25. except StopIteration:
  26. break
  27.  
  28. #集合
  29. l={1,2,3,4,5}
  30. iter_l=l.__iter__()
  31. while True:
  32. try:
  33. print(iter_l.__next__())
  34. except StopIteration:
  35. break

实例说明

3.迭代器的优缺点:

  1. '''
  2. 优点:
  3. 1.提供了一种不依靠索引取值的迭代方式
  4. 2.执行一次.__next__()方法往内存读一条数据,节省内存
  5.  
  6. 缺点:
  7. 1.无法用len(),甚至在数据读完之前都不会知道数据有多少
  8. 2.只能往后走,不能回退
  9. 3.一次性的
  10. '''

补充for循环

  1. with open('db.txt','r',encoding='utf-8') as f:
  2. for line in f:
  3. print(line)
  4.  
  5. #执行in后的iter_f=f.__iter__()方法得到迭代器对象
  6. #执行iter_f.__next__(),将得到的值赋值给line,执行循环体代码
  7. #重复第二步,直到程序抛出StopIteration异常,结束循环

二、生成器

  1. '''
  2. 生成器就是迭代器。
  3. 当函数体内有yield时,那么函数名()的结果就是生成器,yield不会执行函数体代码而是保存函数的运行状态。
  4. '''
  5. def chicken():
  6. print('>>>1')
  7. yield 1
  8. print('>>>2')
  9. yield 2
  10.  
  11. obj=chicken()#拿到生成器对象
  12. print(obj)#<generator object chicken at 0x000001B3FD8580A0>
  13.  
  14. res=obj.__next__()#执行第一行,返回>>>1
  15. print(res)#1
  16.  
  17. res2=obj.__next__()
  18. print(res2)
  19. res3=obj.__next__()#StopIteration
  1. def eat(name):
  2. print('%s ready to eat'%name)
  3. while True:
  4. food=yield
  5. print('%s start to eat %s'%(name,food))
  6.  
  7. name=input('投喂对象>>>').strip()
  8. obj=eat(name)
  9. obj.__next__()
  10. food=input('食物>>>').strip()
  11. obj.send(food)

喂狗小程序

  1. def is_range(start,stop,step=1):
  2. n=start
  3. while n<stop:
  4. yield n
  5. n+=step
  6.  
  7. for i in is_range(10):
  8. print(i)
  9.  
  10. #小改动
  11. def my_range(start=0,stop=1,step=1):
  12. n=start
  13. while n<stop:
  14. yield n
  15. n+=step
  16.  
  17. for i in my_range(2,10,2):
  18. print(i)

自制迭代器

三、面向过程编程

  1. '''
  2. 不同的编程范式像不同的武林门派。
  3. 面向过程的编程思想:
  4. 核心就是‘过程’二字,即解决问题的过程
  5. 面向过程编程就好比设计一条流水线,是种机械式的思维方式。
  6.  
  7. 优点:复杂问题流程化、简单化
  8. 缺点:扩展性差,连锁反应
  9. 应用:用于扩展性要求低的场景
  10. '''

python之迭代器、生成器与面向过程编程的更多相关文章

  1. python第四周迭代器生成器序列化面向过程递归

      第一节装饰器复习和知识储备------------ 第一节装饰器复习和知识储备------------ def wrapper(*args,**kwargs): index(*args,**kwa ...

  2. python全栈开发-Day11 迭代器、生成器、面向过程编程

    一. 迭代器 一 .迭代的概念 迭代器即迭代的工具,那什么是迭代呢? 迭代是一个重复的过程,每次重复即一次迭代,并且每次迭代的结果都是下一次迭代的初始值 while True: #只是单纯地重复,因而 ...

  3. Python之路【第六篇】:Python迭代器、生成器、面向过程编程

    阅读目录 一.迭代器 1.迭代的概念 #迭代器即迭代的工具,那什么是迭代呢? #迭代是一个重复的过程,每次重复即一次迭代,并且每次迭代的结果都是下一次迭代的初始值 代码如下: while True: ...

  4. python之迭代器、生成器、面向过程编程

    一 迭代器 一 迭代的概念 #迭代器即迭代的工具,那什么是迭代呢?#迭代是一个重复的过程,每次重复即一次迭代,并且每次迭代的结果都是下一次迭代的初始值 while True: #只是单纯地重复,因而不 ...

  5. python之旅:迭代器、生成器、面向过程编程

    1.什么是迭代器? 1.什么是迭代器 迭代的工具 什么是迭代? 迭代是一个重复的过程,每一次重复都是基于上一次结果而进行的 # 单纯的重复并不是迭代 while True: print('=====& ...

  6. python基础知识14---迭代器、生成器、面向过程编程

    阅读目录 一 迭代器 二 生成器 三 面向过程编程 一 迭代器 1 迭代的概念 #迭代器即迭代的工具,那什么是迭代呢? #迭代是一个重复的过程,每次重复即一次迭代,并且每次迭代的结果都是下一次迭代的初 ...

  7. Python 迭代器-生成器-面向过程编程

    上节课复习:1. 函数的递归调用 在调用一个函数的过程中又直接或者间接地调用了函数本身称之为函数的递归 函数的递归调用有两个明确的阶段: 1. 回溯 一层一层地调用本身 注意: 1.每一次调用问题的规 ...

  8. 匿名函数 python内置方法(max/min/filter/map/sorted/reduce)面向过程编程

    目录 函数进阶三 1. 匿名函数 1. 什么是匿名函数 2. 匿名函数的语法 3. 能和匿名函数联用的一些方法 2. python解释器内置方法 3. 异常处理 面向过程编程 函数进阶三 1. 匿名函 ...

  9. python函数:匿名函数、函数递归与二分法、面向过程编程

    今天主要讲三大部分内容: 一.匿名函数二.函数递归与二分法三.面向过程编程 一.匿名函数: """ 1. 什么时匿名函数 def定义的是有名函数:特点是可以通过名字重复调 ...

随机推荐

  1. Git要点

    前面的话 本文将总结Git要点 版本管理工具 [作用] 1.备份文件 2.记录历史 3.回到过去 4.对比差异 [分类] 1.手动版本控制(又叫人肉VCS) 2.LVCS 本地 3.CVCS 集中式( ...

  2. 一个简易的C语言文法

    <程序>→<外部声明>|<程序><外部声明> <外部声明>→<函数定义>|<声明> <函数定义>→< ...

  3. c++ string去除首尾 空格、\n、\r、\t

    string s = " test "; size_t n = s.find_last_not_of(" \r\n\t"); if (n != string:: ...

  4. MongoDB数据模型设计

    MongoDB的数据模式是一种灵活模式,其集合并不限制文档结构.这种灵活性让对象和数据库文档之间的映射变得很容易,即使数据记录之间有很大的变化,每个文档也可以很好的映射到各条不同的记录.但在实际使用中 ...

  5. $.ajax ,ajax请求添加请求头,添加Authorization字段

    beforeSend : function(request) { request.setRequestHeader("Authorization", sessionStorage. ...

  6. Codeforces Round #472 Div. 1

    A:某个格子被染黑说明该行和该列同时被选中,使用并查集合并,最后看每个集合中是否有未被染黑的格子即可. #include<iostream> #include<cstdio> ...

  7. HDU5769-Substring-多校#4-1006-后缀数组

    给定一个字符x和一个字符串.要求输出包含此字符的所有不同字串. 后缀数组可以计算一个字符串的所有不同字串,理解了原理就能做这题了. 对于每一个后缀i,将产生len-sa[i]-hight[i]的前缀, ...

  8. CH2601 电路维修(算竞进阶习题)

    01边bfs 这题很容易想到的就是根据符号的情况建图,把每个点方格的对角线看成图的节点,有线相连就是边权就是0,没有就是1 然后跑最短路,但是最短路用的优先队列维护是有logn的代价的 这题还有一个更 ...

  9. MT【269】含参函数绝对值最大

    设函数$f(x)=ax^2+(2b+1)x-a-2$($a,b\in\mathcal R$,$a\neq 0$). (1) 若$a=-2$,求函数$y=|f(x)|$在$[0,1]$上的最大值$M(b ...

  10. AES解密后多了\0

    AES加密解密之后发现多了几个空格,不知道原因.在调试时发现多了\0这种东西 不知道为什么会多这些.后来.replace("\0","")这样做了事