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

相关文章

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、