目录


一、迭代器

1.迭代器的概念理解

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

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

'''
(1)可迭代对象:
可迭代对象就是内置__iter__方法的对象(再次重申,python中一切皆对象)。
(2)迭代器对象就是内置有__iter__方法和__next__方法的对象。 可迭代对象执行了obj.__iter__()得到的结果就是迭代器对象,迭代器对象执行了obj.__iter__()得到的是迭代器本身。 要明确的一点是迭代器对象一定是可迭代对象,但是可迭代对象不一定是迭代器对象。
'''
#字符串
string='hello world'
iter_st=string.__iter__()
while True:
try:
print(iter_st.__next__())
except StopIteration:
break #列表
s=[1,3,4,5,'a']
iter_s=s.__iter__()
while True:
try:
print(iter_s.__next__())
except StopIteration:
break #字典
dic={'a':1,'b':2}
iter_dic=dic.__iter__()
while True:
try:
print(iter_dic.__next__())
except StopIteration:
break #集合
l={1,2,3,4,5}
iter_l=l.__iter__()
while True:
try:
print(iter_l.__next__())
except StopIteration:
break

实例说明

3.迭代器的优缺点:

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

补充for循环

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

二、生成器

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

喂狗小程序

def is_range(start,stop,step=1):
n=start
while n<stop:
yield n
n+=step for i in is_range(10):
print(i) #小改动
def my_range(start=0,stop=1,step=1):
n=start
while n<stop:
yield n
n+=step for i in my_range(2,10,2):
print(i)

自制迭代器

三、面向过程编程

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

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. HTML中文本过长时自动隐藏末尾部分或中间等任意部分

    一.    一般情况下,HTML字符串过长时都会将超过的部分隐藏点,方法如下: 设置CSS: .ellipsis-type{ max-width: 50px;                      ...

  2. DotNetty 实现 Modbus TCP 系列 (一) 报文类

    本文已收录至:开源 DotNetty 实现的 Modbus TCP/IP 协议 Modbus TCP/IP 报文 报文最大长度为 260 byte (ADU = 7 byte MBAP Header ...

  3. hdu 4578 Transformation 线段树多种操作裸题

    自己写了一个带结构体的WA了7.8次 但是测了几组小数据都对..感觉问题应该出在模运算那里.写完这波题解去对拍一下. 以后线段树绝不写struct!一般的struct都带上l,r 但是一条线段的长度确 ...

  4. mysql中count的注意事项

    1.count()函数是用来统计表中记录的一个函数,返回匹配条件的行数. 2.count()语法: (1)count(*)---包括所有列,返回表中的记录数,相当于统计表的行数,在统计结果的时候,不会 ...

  5. 第四十一天 socker server和 event

    今日内容 1.基于TCP的socketserver 2.基于UDP的socketserver 3.event 一.TCP的socketserver #服务器 import socketserver f ...

  6. G - Balanced Lineup POJ - 3264 线段树最大最小值区间查询模版题

    题意 给出一个序列  每次查询区间的max-min是多少 思路:直接维护max 和min即可  写两个query分别查最大最小值 #include<cstdio> #include< ...

  7. 青蛙的约会 POJ - 1061 (exgcd)

    两只青蛙在网上相识了,它们聊得很开心,于是觉得很有必要见一面.它们很高兴地发现它们住在同一条纬度线上,于是它们约定各自朝西跳,直到碰面为止.可是它们出发之前忘记了一件很重要的事情,既没有问清楚对方的特 ...

  8. luogu P3128 [USACO15DEC]最大流Max Flow (树上差分)

    题目描述 Farmer John has installed a new system of N-1N−1 pipes to transport milk between the NN stalls ...

  9. 基于 __new__ 方法的单例模式

    单例模式定义 首次实例化创建实例化对象 之后的每次实例化都用最初的实例化对象 即单实例模式 __new__ 的原理 __new__ 方法可以在 __init__ 方法执行 这样可以在初始化之前进行一系 ...

  10. 网络流相关知识点以及题目//POJ1273 POJ 3436 POJ2112 POJ 1149

    首先来认识一下网络流中最大流的问题 给定一个有向图G=(V,E),把图中的边看做成管道,边权看做成每根管道能通过的最大流量(容量),给定源点s和汇点t,在源点有一个水源,在汇点有一个蓄水池,问s-t的 ...