目录
可迭代对象有哪些:
在python中,可迭代对象一共有4种。分别是str(字符串)、list(列表)、tuple(元组)、dict(字典)。
为什么称为可迭代对象:
因为这几种数据类型都遵守了可迭代协议。
可迭代协议
由iterable表示可迭代协议,需满足以下两个条件。
(1)该对象实现了__iter__()方法;
(2)该对象实现了next()方法,返回当前元素,并指向下一个元素的位置,如果当前位置已无元素,则抛出StopIteration异常。
怎么判断是否是可迭代对象
使用dlr()函数查看输出内容内是否有__iter__,如果存在则表示这是一共可迭代对象。dir函数作用是可以查看目标的内置方法和函数。
content_str = 'hello' # 字符串类型
print(dir(content_str))
'''
['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__',
'__getattribute__', '__getitem__', '__getnewargs__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__',
'__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__',
'__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center',
'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isascii',
'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper',
'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'removeprefix', 'removesuffix', 'replace', 'rfind',
'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase',
'title', 'translate', 'upper', 'zfill']
'''
content_list = [1, 2] # 列表类型
print(dir(content_list))
'''
['__add__', '__class__', '__class_getitem__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__',
'__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__gt__', '__hash__', '__iadd__', '__imul__',
'__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__',
'__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__rmul__', '__setattr__', '__setitem__', '__sizeof__',
'__str__', '__subclasshook__', 'append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove',
'reverse', 'sort']
'''
content_tuple = (1, 2) # 元组类型
print(dir(content_tuple))
'''
['__add__', '__class__', '__class_getitem__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__',
'__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__gt__', '__hash__', '__init__',
'__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__',
'__reduce_ex__', '__repr__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'count', 'index']
'''
content_dict = {'我': 1} # 字典类型
print(dir(content_dict))
'''
['__class__', '__class_getitem__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__',
'__format__', '__ge__', '__getattribute__', '__getitem__', '__gt__', '__hash__', '__init__', '__init_subclass__',
'__ior__', '__iter__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__or__', '__reduce__', '__reduce_ex__',
'__repr__', '__reversed__', '__ror__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__',
'clear', 'copy', 'fromkeys', 'get', 'items', 'keys', 'pop', 'popitem', 'setdefault', 'update', 'values']
'''
以上4种类型种输出内容中都有__iter__方法,所以这4种都是可迭代对象
__iter__方法
表示从可迭代对象中获取迭代器,然后才能进行迭代操作
格式:
变量名.__iter__()
__next__方法
表示对迭代器进行迭代操作
格式:
迭代器.__next__()
例子:
content_str = 'hello'
content_iter = content_str.__iter__() # 获取迭代器
# 进行迭代操作
print(content_iter.__next__()) # 输出结果为h
print(content_iter.__next__()) # 输出结果为e
print(content_iter.__next__()) # 输出结果为l
print(content_iter.__next__()) # 输出结果为l
print(content_iter.__next__()) # 输出结果为o
注意:如果迭代操作次数大于了迭代器长度,则会报错StopIteration,表示以停止迭代了。
怎么判断是否是迭代器
与判断是否是迭代对象方式类似,同样可以使用dir()函数,如果输出内容中同时有__iter__、__next__两个方法,则表示它是迭代器
content_str = 'hello'
content_iter = content_str.__iter__() #获取迭代器
print(dir(content_iter))
'''
['__class__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__',
'__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__length_hint__', '__lt__', '__ne__', '__new__',
'__next__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__setstate__', '__sizeof__', '__str__',
'__subclasshook__']
'''
for循环的工作原理
for循环的工作本质就是while循环加迭代器。
content_str = 'hello'
content_iter = content_str.__iter__() #获取迭代器
while True: #死循环
try:
print(content_iter.__next__())
except StopIteration: #表示当报这个错误时,则跳出循环
break
代码中的try eccppt语句表示捕捉异常,当报错StopIteration时,则跳出循环。
迭代器的特点
惰性进制
表示你每操作一次迭代器,他才会运行一次迭代器内部的内容,而不会一口气全部运行出来
不能反复,只能向下执行
只能一直向下运行迭代器的内容,运行一次后不会再重复运行该内容
节省内存
因为惰性机制,而且在对迭代器操作前,迭代器只会占用内存地址空间。不会占用其他空间
content_str = 'hello'
content_iter = content_str.__iter__() # 获取迭代器
print(content_iter) # <str_iterator object at 0x0000029B5F1A6C80>