python基础-迭代器、for底层机制、生成器、list结合yield、__call__、yield函数列表

本文主要是介绍python基础-迭代器、for底层机制、生成器、list结合yield、__call__、yield函数列表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        • 迭代器概念
        • for底层机制
        • 生成器
          • 最简单的生成器
          • 返回列表字典元组等
          • 返回多个值构成元组
        • 返回一个函数列表
          • list结合yield
        • _call_
          • 多个yield形式

迭代器概念

可迭代的必须含有一个iter方法(可迭代协议)
迭代器比可迭代对象多一个next方法
包含next方法的可迭代对象就是迭代器
迭代器:包含next,iter方法的就是迭代器(迭代器协议)
迭代器是可迭代的一部分

#爬虫作业#获取列表的方法
print(dir(["safly"]))
#拿到迭代器
print("abc".__iter__())#依次取值
ite = "abc".__iter__()
print(ite.__next__())
print(ite.__next__())
print(ite.__next__())#可迭代对象、迭代器
print("------")
l = ["a"]
print(dir(l))
print(dir(l.__iter__()))
#多3个方法
#{'__length_hint__', '__next__', '__setstate__'}
print(set(dir(l.__iter__()))- set(dir(l)))#1、如何判断是否是可迭代对象或者迭代器?
print("__iter__" in dir('sss'))
print("__next__" in dir("sss"))#2、如何判断是否是可迭代对象或者迭代器?
from collections import  Iterable
from collections import  Iterator
print(isinstance("a",int))
print(isinstance("a",Iterable))str_  = "abc".__iter__()
print(isinstance(str_,Iterator))

输出如下:

E:\python\python_sdk\python.exe E:/python/py_pro/1103.py
['__add__', '__class__', '__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']
<str_iterator object at 0x02EC1690>
a
b
c
------
['__add__', '__class__', '__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']
['__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__']
{'__setstate__', '__length_hint__', '__next__'}
True
False
False
True
TrueProcess finished with exit code 0
for底层机制
li = [1,3,4,5]
it = li.__iter__()
while True:try:print(it.__next__())except StopIteration:break

输出如下:

1
3
4
5
生成器

生成器的本质就是迭代器
只不过是我们自己写的python代码
生成器2种方式
1、生成器函数
2、生成器表达式
生成器函数,调用不执行,而是返回一个生成器,是一个迭代器

最简单的生成器
def g_func():print("---g_func---")yield 1g = g_func()
print(g)
print(g.__next__())

输出如下:

<generator object g_func at 0x03006540>
---g_func---
1

返回了一个值1

返回列表,字典,元组等
def g_func():print("---g_func---")yield [1,2,3]g = g_func()
print(g)
print(g.__next__())

输出如下:

<generator object g_func at 0x02A862A0>
---g_func---
[1, 2, 3]

我们看下是返回了一个列表[1, 2, 3]

返回多个值,构成元组
def cloth(a):print("aaaa")cloth = ayield "第{}件衣服".format(cloth),"yyyyy"g = cloth(100)
h = g.__next__()
print(h)
print("------")
print(type(h))
print("------")
for i in h:print(i)

输出如下:

aaaa
('第100件衣服', 'yyyyy')
------
<class 'tuple'>
------
第100件衣服
yyyyy
返回一个函数列表
def yie():def a():print("--a")def b():print("--b")yield [a,b]yie = yie()
next = yie.__next__()
print(next)next[0].__call__()
next[0]()next[1].__call__()
next[1]()print("------------")def a():print('调用')x = a
x.__call__()
x()

输出如下:

E:\python\python_sdk\python.exe E:/python/py_pro/1104.py
[<function yie.<locals>.a at 0x009BD660>, <function yie.<locals>.b at 0x00B028E8>]
--a
--a
--b
--b
------------
调用
调用Process finished with exit code 0
list结合yield
def aaa():yield 1,2yield (3,4)yield {"a":"b"}yield "saf"yield 1yield Truey = list(aaa())
print(y)y = aaa()
print(y.__next__())
print(y.__next__())
print(y.__next__())
print(y.__next__())
print(y.__next__())
print(y.__next__())

输出如下:

E:\python\python_sdk\python.exe E:/python/py_pro/1104.py
[(1, 2), (3, 4), {'a': 'b'}, 'saf', 1, True]
(1, 2)
(3, 4)
{'a': 'b'}
saf
1
TrueProcess finished with exit code 0
_call_
def a():print("--a")def b():print("--b")lis = [a,b]ite = lis.__iter__()
ite.__next__().__call__()
ite.__next__().__call__()

输出如下:

E:\python\python_sdk\python.exe E:/python/py_pro/1104.py
--a
--bProcess finished with exit code 0
多个yield形式
def g_func():print("---g_func1---")yield [1,2]print("---g_func2---")print("---g_func3---")yield [3,4]print("---g_func4---")g = g_func()
print(g)
print(g.__next__())
print(g.__next__())

输出如下:

<generator object g_func at 0x039E62A0>
---g_func1---
[1, 2]
---g_func2---
---g_func3---
[3, 4]

这篇关于python基础-迭代器、for底层机制、生成器、list结合yield、__call__、yield函数列表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125212

相关文章

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

一文带你搞懂Python中__init__.py到底是什么

《一文带你搞懂Python中__init__.py到底是什么》朋友们,今天我们来聊聊Python里一个低调却至关重要的文件——__init__.py,有些人可能听说过它是“包的标志”,也有人觉得它“没... 目录先搞懂 python 模块(module)Python 包(package)是啥?那么 __in

使用Python实现图像LBP特征提取的操作方法

《使用Python实现图像LBP特征提取的操作方法》LBP特征叫做局部二值模式,常用于纹理特征提取,并在纹理分类中具有较强的区分能力,本文给大家介绍了如何使用Python实现图像LBP特征提取的操作方... 目录一、LBP特征介绍二、LBP特征描述三、一些改进版本的LBP1.圆形LBP算子2.旋转不变的LB

Python中__init__方法使用的深度解析

《Python中__init__方法使用的深度解析》在Python的面向对象编程(OOP)体系中,__init__方法如同建造房屋时的奠基仪式——它定义了对象诞生时的初始状态,下面我们就来深入了解下_... 目录一、__init__的基因图谱二、初始化过程的魔法时刻继承链中的初始化顺序self参数的奥秘默认

Python实现特殊字符判断并去掉非字母和数字的特殊字符

《Python实现特殊字符判断并去掉非字母和数字的特殊字符》在Python中,可以通过多种方法来判断字符串中是否包含非字母、数字的特殊字符,并将这些特殊字符去掉,本文为大家整理了一些常用的,希望对大家... 目录1. 使用正则表达式判断字符串中是否包含特殊字符去掉字符串中的特殊字符2. 使用 str.isa

python中各种常见文件的读写操作与类型转换详细指南

《python中各种常见文件的读写操作与类型转换详细指南》这篇文章主要为大家详细介绍了python中各种常见文件(txt,xls,csv,sql,二进制文件)的读写操作与类型转换,感兴趣的小伙伴可以跟... 目录1.文件txt读写标准用法1.1写入文件1.2读取文件2. 二进制文件读取3. 大文件读取3.1

使用Python实现一个优雅的异步定时器

《使用Python实现一个优雅的异步定时器》在Python中实现定时器功能是一个常见需求,尤其是在需要周期性执行任务的场景下,本文给大家介绍了基于asyncio和threading模块,可扩展的异步定... 目录需求背景代码1. 单例事件循环的实现2. 事件循环的运行与关闭3. 定时器核心逻辑4. 启动与停

基于Python实现读取嵌套压缩包下文件的方法

《基于Python实现读取嵌套压缩包下文件的方法》工作中遇到的问题,需要用Python实现嵌套压缩包下文件读取,本文给大家介绍了详细的解决方法,并有相关的代码示例供大家参考,需要的朋友可以参考下... 目录思路完整代码代码优化思路打开外层zip压缩包并遍历文件:使用with zipfile.ZipFil