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定义的是有名函数:特点是可以通过名字重复调 ...
随机推荐
- Git要点
前面的话 本文将总结Git要点 版本管理工具 [作用] 1.备份文件 2.记录历史 3.回到过去 4.对比差异 [分类] 1.手动版本控制(又叫人肉VCS) 2.LVCS 本地 3.CVCS 集中式( ...
- endnote插入文献时出现{,#}这样的乱码
1)在每次插入文献后,再点击一下Bibliography里面的Update Citation and Bibliography即可: (2)较好的解决方法也较为简单,只需要再一次进入Word中的End ...
- 洛谷 P2921 [USACO08DEC]在农场万圣节Trick or Treat on the Farm
题目描述 每年,在威斯康星州,奶牛们都会穿上衣服,收集农夫约翰在N(1<=N<=100,000)个牛棚隔间中留下的糖果,以此来庆祝美国秋天的万圣节. 由于牛棚不太大,FJ通过指定奶牛必须遵 ...
- 使用Guava获取某一个类的指定超类上的泛型Type T
package com.geostar.gfstack.operationcenter.log.common.hibernate; import com.geostar.gfstack.operati ...
- springcloud 学习
参考: spring cloud 入门系列一:初识spring cloud http://blog.didispace.com/Spring-Cloud%E5%9F%BA%E7%A1%80%E6%95 ...
- D - Mayor's posters POJ - 2528 离散化+线段树 区间修改单点查询
题意 贴海报 最后可以看到多少海报 思路 :离散化大区间 其中[1,4] [5,6]不能离散化成[1,2] [2,3]因为这样破坏了他们的非相邻关系 每次离散化区间 [x,y]时 把y+1点也加入 ...
- Django+Vue打造购物网站(一)
环境搭建 python == 3.6 Django == 2.0 创建工程 django-admin startproject MxShop 配置setting.py文件 # 数据库 DATABASE ...
- 【XSY2701】异或图 线性基 容斥原理
题目描述 定义两个图\(G_1\)与\(G_2\)的异或图为一个图\(G\),其中图\(G\)的每条边在\(G_1\)与\(G_2\)中出现次数和为\(1\). 给你\(m\)个图,问你这\(m\)个 ...
- Codeforces Round #530 (Div. 2) A,B,C,D
A. Snowball 链接:http://codeforces.com/contest/1099/problem/A 思路:模拟 代码: #include<bits/stdc++.h> ...
- 【Gym - 100947G】Square Spiral Search
BUPT 2017 summer training (for 16) #1C 题意 A new computer scientist is trying to develop a new memory ...