python之迭代器、生成器与面向过程编程
目录
一、迭代器
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之迭代器、生成器与面向过程编程的更多相关文章
- python第四周迭代器生成器序列化面向过程递归
第一节装饰器复习和知识储备------------ 第一节装饰器复习和知识储备------------ def wrapper(*args,**kwargs): index(*args,**kwa ...
- python全栈开发-Day11 迭代器、生成器、面向过程编程
一. 迭代器 一 .迭代的概念 迭代器即迭代的工具,那什么是迭代呢? 迭代是一个重复的过程,每次重复即一次迭代,并且每次迭代的结果都是下一次迭代的初始值 while True: #只是单纯地重复,因而 ...
- Python之路【第六篇】:Python迭代器、生成器、面向过程编程
阅读目录 一.迭代器 1.迭代的概念 #迭代器即迭代的工具,那什么是迭代呢? #迭代是一个重复的过程,每次重复即一次迭代,并且每次迭代的结果都是下一次迭代的初始值 代码如下: while True: ...
- python之迭代器、生成器、面向过程编程
一 迭代器 一 迭代的概念 #迭代器即迭代的工具,那什么是迭代呢?#迭代是一个重复的过程,每次重复即一次迭代,并且每次迭代的结果都是下一次迭代的初始值 while True: #只是单纯地重复,因而不 ...
- python之旅:迭代器、生成器、面向过程编程
1.什么是迭代器? 1.什么是迭代器 迭代的工具 什么是迭代? 迭代是一个重复的过程,每一次重复都是基于上一次结果而进行的 # 单纯的重复并不是迭代 while True: print('=====& ...
- python基础知识14---迭代器、生成器、面向过程编程
阅读目录 一 迭代器 二 生成器 三 面向过程编程 一 迭代器 1 迭代的概念 #迭代器即迭代的工具,那什么是迭代呢? #迭代是一个重复的过程,每次重复即一次迭代,并且每次迭代的结果都是下一次迭代的初 ...
- Python 迭代器-生成器-面向过程编程
上节课复习:1. 函数的递归调用 在调用一个函数的过程中又直接或者间接地调用了函数本身称之为函数的递归 函数的递归调用有两个明确的阶段: 1. 回溯 一层一层地调用本身 注意: 1.每一次调用问题的规 ...
- 匿名函数 python内置方法(max/min/filter/map/sorted/reduce)面向过程编程
目录 函数进阶三 1. 匿名函数 1. 什么是匿名函数 2. 匿名函数的语法 3. 能和匿名函数联用的一些方法 2. python解释器内置方法 3. 异常处理 面向过程编程 函数进阶三 1. 匿名函 ...
- python函数:匿名函数、函数递归与二分法、面向过程编程
今天主要讲三大部分内容: 一.匿名函数二.函数递归与二分法三.面向过程编程 一.匿名函数: """ 1. 什么时匿名函数 def定义的是有名函数:特点是可以通过名字重复调 ...
随机推荐
- How the Microsoft Bot Framework Changed Where My Friends and I Eat: Part 1
Bots are everywhere nowadays, and we interact with them all of the time. From interactions on our ph ...
- Nginx 慢启动与拥塞窗口
L:127
- NAND闪存供过于求的情况今年会有所好转吗?
2018年,NAND闪存全年供过于求,价格一直下跌,导致西数.东芝等厂商毛利率大幅下滑.如今到了2019年,情况会有所好转吗? 近日,集邦科技旗下半导体研究中心DRAMeXchange发布调查报告指出 ...
- 创建第一个Djiago
Djiago 目录介绍 mysite/ ├── manage.py # 管理文件 └── mysite # 项目目录 ├── __init__.py ├── settings.py # 配置 ├── ...
- ubuntu18.04系统下用devstack安装openstack(最新版)
ubuntu18.04系统下用devstack安装openstack(最新版) 2018年12月14日 16:34:14 Cherls 阅读数:427 前期准备: 安装git,升级pip,其他 s ...
- Java中的CopyOnWrite
CopyOnWrite简称COW,是一种程序设计的一种优化的策略方法,他开始的思想就是大家一起共享一件东西或商品,当一个人想要改这个事物原有的状态时,会重新复制一份出去,然后再新的事物上面改他所需要的 ...
- 序列化模块组 pickle,json , xml , shelve , configparser
序列化是什么? 序列化指的是将内存中的数据结构转化为一种中间格式 并存储到硬盘上. 反序列化是什么? 将硬盘上存储的中间格式数据再还原为内存中的数据结构. 为什么要有序列化? 是为了将数据持久存储 较 ...
- FWT模板(洛谷P4717 【模板】快速沃尔什变换)(FWT)
洛谷题目传送门 只是一个经过了蛇皮压行的模板... 总结?%%%yyb%%% #include<bits/stdc++.h> #define LL long long #define RG ...
- 【BZOJ5318】[JSOI2018]扫地机器人(动态规划)
[BZOJ5318][JSOI2018]扫地机器人(动态规划) 题面 BZOJ 洛谷 题解 神仙题.不会.... 先考虑如果一个点走向了其下方的点,那么其右侧的点因为要被访问到,所以必定只能从其右上方 ...
- 【BZOJ2618】[CQOI2006]凸多边形(半平面交)
[BZOJ2618][CQOI2006]凸多边形(半平面交) 题面 BZOJ 洛谷 题解 这个东西就是要求凸多边形的边所形成的半平面交. 那么就是一个半平面交模板题了. 这里写的是平方的做法. #in ...