python学习之可迭代对象迭代器对象
可迭代对象 Iterable
含义:可以通过for...in..。这类语句遍历读取数据的对象称之为可迭代对象
遍历(迭代):依次从对象中把一个个元素取出来的过程
数据类型: str、list、tuple、dict、set等
可迭代对象的条件
1.对象实现了__iter__()方法
2.__iter__()方法返回了迭代器对象
1.3 for循环工作原理
1.先通过__iter__()可迭代对象的迭代器
2.对获取到的迭代器对象不断调用__next__()方法来获取
下一个值并将其赋值给临时变量i
1.4 isinstance():判断一个对象是否是可迭代对象或者是一个已知的数据类型
导入模块
from collections.abc import Iterable # isinstance(o,t) o--对象,t--类型,可以是直接或间接类名、基本类型或者元组 print(isinstance(123,Iterable)) #False print(isinstance('123',Iterable)) #True print(isinstance(123,(int,float,str))) #是其中的一种就会返回True
2.迭代器 Iterator
含义:迭代器是一个可以记住遍历位置的对象,迭代器对象从集合的第一个元素开始访问,知道所有元素被访问完结束。迭代器只能往前不能退后
迭代器里面有两个函数
iter():获取可迭代对象的迭代器
next():一个个去取元素,取完元素后会引发一个异常
li = [1,2,3] # 第一种方式: # 1.创建迭代器对象 li2 = iter(li) print('li2',li2) # 2.获取下一条数据 print(next(li2)) print(next(li2)) print(next(li2)) # 3.取完元素之后,再使用next()会引发StopIteration异常 print(next(li2)) # 第二种方式: li2 = li.__iter__() print('li2',li2) print(li2.__next__()) print(dir(li))
步骤:
1.iter()调用对象的__iter__(),并把__iter__()方法的返回结果作为自己的返回值
2.next()调用对象的__next__(),一个个取元素
3.所有的元素都取完了,__next__()就会引发StopIteration异常
可迭代对象 Iterable 迭代器 Iterator
凡是可以作用于for循环的都属于可迭代对象
凡是可作用于next()的都是迭代器
from collections.abc import Iterable,Iterator name = 'milk' print(isinstance(name,Iterable)) #True print(isinstance(name,Iterator)) #False # 可迭代对象并不一定是迭代器对象 name2 = iter(name) #将name转换为迭代器 print(isinstance(name2,Iterable)) #True print(isinstance(name2,Iterator)) #True
迭代器对象一定是可迭代对象 总结: 可迭代对象可以通过iter()转化成迭代器对象 如果一个对象拥有__iter__(),是可迭代对象,如果一个对象拥有__next__()和__iter__()方法,是迭代器对象 dir(): 查看对象中的属性和方法
3.迭代器协议
对象必须提供一个方法,执行该方法,要么就返回迭代器中的下一项,要么就引发StopIteration异常,来终止迭代
4.自定义迭代器类
两个特性: __iter__()方法和__next__()方法
class Test(object):def __init__(self):self.num = 1def func(self):print(self.num)self.num += 1 test = Test() print(test) # test.func() # test.func() # test.func() for i in range(10):test.func()
class MyIterator(object):def __init__(self,max_num):self.num = 0self.max = max_numdef __iter__(self):return self #返回的是当前迭代器类的实例对象def __next__(self):if self.num >= self.max:raise StopIteration("数据已经被取完了")self.num += 1return self.num mi = MyIterator(100) print(mi) for i in mi:print(i)