Python中的 for 与 迭代器
文章目录
- 一、`for` 循环的底层机制
- 示例:手动模拟 `for` 循环
- 二、可迭代对象 vs 迭代器
- 关键区别:
- 三、`for` 循环的典型应用场景
- 1. 遍历序列类型
- 2. 遍历字典
- 3. 结合 `range()` 生成数字序列
- 4. 遍历文件内容
- 四、迭代器的自定义实现
- 示例:生成斐波那契数列的迭代器
- 五、生成器(简化迭代器)
- 示例:生成偶数序列
- 六、迭代工具库 `itertools`
- 示例:合并多个迭代器
- 七、常见问题与最佳实践🐥🐥
- 1. 避免在迭代中修改集合
- 2. 使用 `enumerate()` 获取索引
- 3. 利用 `zip()` 并行遍历
- 总结
在 Python 中,
for
循环与迭代器(iterator)紧密结合,它们共同实现了对可迭代对象(iterable)的高效遍历。以下是详细解析及实际应用示例:
一、for
循环的底层机制
for
循环本质上是通过迭代器协议工作的:
- 自动调用
iter()
函数,将可迭代对象(如列表、字符串、字典)转换为迭代器。 - 反复调用
next()
函数获取元素,直到触发StopIteration
异常时退出循环。
示例:手动模拟 for
循环
numbers = [1, 2, 3]
iterator = iter(numbers) # 转换为迭代器
while True:try:num = next(iterator) # 获取下一个元素print(num)except StopIteration: # 遍历完成break
# 输出:1 2 3
二、可迭代对象 vs 迭代器
类别 | 定义 | 示例 |
---|---|---|
可迭代对象 | 实现了 __iter__() 方法的对象 | list , str , dict |
迭代器 | 实现了 __iter__() 和 __next__() 方法的对象 | iterator = iter([1,2,3]) |
关键区别:
- 可迭代对象:可被多次遍历(每次
for
循环会创建新迭代器)。 - 迭代器:遍历一次后耗尽(无法重置,再次调用
next()
会触发异常)。
三、for
循环的典型应用场景
1. 遍历序列类型
# 遍历列表
fruits = ["apple", "banana", "cherry"]
for fruit in fruits:print(fruit)# 遍历字符串
text = "Hello"
for char in text:print(char)
2. 遍历字典
person = {"name": "Alice", "age": 30, "city": "Paris"}
for key in person: # 默认遍历键print(key)for key, value in person.items(): # 同时遍历键值对print(f"{key}: {value}")
3. 结合 range()
生成数字序列
for i in range(3): # 0, 1, 2print(i)for i in range(1, 5, 2): # 1, 3print(i)
注意:range()作为Python中的一个内置函数,调用会产生一个迭代序列。
如果range()产生的序列为空,那么用该迭代器控制for循环的时候,
其循环体将一次也不执行,循环立刻结束。
4. 遍历文件内容
with open("data.txt", "r") as file:for line in file: # 逐行读取文件print(line.strip())
四、迭代器的自定义实现
通过实现 __iter__()
和 __next__()
方法创建自定义迭代器。
示例:生成斐波那契数列的迭代器
class FibonacciIterator:def __init__(self, max_count):self.max_count = max_countself.count = 0self.a, self.b = 0, 1def __iter__(self):return selfdef __next__(self):if self.count >= self.max_count:raise StopIterationresult = self.aself.a, self.b = self.b, self.a + self.bself.count += 1return result# 使用迭代器
fib = FibonacciIterator(5)
for num in fib:print(num) # 输出:0 1 1 2 3
五、生成器(简化迭代器)
使用 yield
关键字快速创建迭代器,无需手动实现类。
示例:生成偶数序列
def even_numbers(max_num):num = 0while num <= max_num:yield numnum += 2for n in even_numbers(10):print(n) # 输出:0 2 4 6 8 10
六、迭代工具库 itertools
Python 内置的 itertools
模块提供多种高级迭代器操作:
示例:合并多个迭代器
import itertools #不要忘了!!!numbers = [1, 2]
letters = ['a', 'b']# 笛卡尔积
for pair in itertools.product(numbers, letters):print(pair) # (1, 'a'), (1, 'b'), (2, 'a'), (2, 'b')# 无限计数器
counter = itertools.count(start=10, step=3)
print(next(counter)) # 10
print(next(counter)) # 13
print(next(counter)) # 16
print(next(counter)) # 19
七、常见问题与最佳实践🐥🐥
1. 避免在迭代中修改集合
# 错误示例:遍历时删除元素会导致意外跳过
numbers = [1, 2, 3, 4]
for num in numbers:if num % 2 == 0:numbers.remove(num) # 危险操作!
print(numbers) # 输出 [1, 3]# 正确方法:遍历副本或使用列表推导式
numbers = [num for num in numbers if num % 2 != 0]
2. 使用 enumerate()
获取索引
fruits = ["apple", "banana", "cherry"]
for index, fruit in enumerate(fruits, start=1): # 索引从1开始print(f"{index}. {fruit}")
输出:
1. apple
2. banana
3. cherry
3. 利用 zip()
并行遍历
names = ["Alice", "Bob"]
ages = [24, 30]
for name, age in zip(names, ages):print(f"{name} is {age} years old")
输出:
Alice is 24 years old
Bob is 30 years old
总结
for
循环本质:基于迭代器协议,自动处理iter()
和next()
。- 迭代器优势:惰性计算(节省内存),适合处理大型数据集。
- 生成器简化:使用
yield
快速创建迭代器。 - 工具扩展:利用
itertools
模块实现复杂迭代逻辑。
掌握迭代器机制,可以编写更高效、灵活的 Python 代码!
喵,就是这样~😼😼😼
相关文章:
Python中的 for 与 迭代器
文章目录 一、for 循环的底层机制示例:手动模拟 for 循环 二、可迭代对象 vs 迭代器关键区别: 三、for 循环的典型应用场景1. 遍历序列类型2. 遍历字典3. 结合 range() 生成数字序列4. 遍历文件内容 四、迭代器的自定义实现示例:生成斐波那契…...
C语言编程--15.四数之和
题目: 给你一个由 n 个整数组成的数组 nums ,和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] (若两个四元组元素一一对应,则认为两个四元组重复)&…...

HTML、XHTML 和 XML区别
HTML、XHTML 和 XML 这三兄弟的区别 HTML: 老大哥,负责网页长啥样,性格比较随和,有点小错误也能容忍。XHTML: 二哥,看着像 HTML,但规矩严,是按 XML 的规矩来的 HTML,更规范。XML: 小弟,负责存储和传输数据,非常灵活,标签可以自己随便定,但规矩最严。它们仨长啥样?(…...
LeetCode 2799.统计完全子数组的数目:滑动窗口(哈希表)
【LetMeFly】2799.统计完全子数组的数目:滑动窗口(哈希表) 力扣题目链接:https://leetcode.cn/problems/count-complete-subarrays-in-an-array/ 给你一个由 正 整数组成的数组 nums 。 如果数组中的某个子数组满足下述条件&am…...
【高中数学/古典概率】4红2黑六选二,求取出两次都是红球的概率
【问题】 袋子里装4只红球,2只黑球,大小完全相同,抽两次球,每次抽一只,抽出后不再放回,求取出的两次都是红球的概率。 【来源】 数林外传系列之《概率与期望》P20 单埻著 中国科学技术大学出版社 【数学…...
QLExpress 深度解析:构建动态规则引擎的利器
QLExpress 深度解析:构建动态规则引擎的利器 在现代业务系统中,“规则变更快、逻辑复杂、发布要求高”已成为常态。传统硬编码已无法满足这种需求。本文以阿里巴巴开源的轻量级表达式引擎 QLExpress 为例,从实际应用、核心结构到落地建议,系统解析其强大能力和设计哲学。 …...
aarcpy 列表函数的使用(1)
arcpy.ListFeatureClasses() 该函数用于列出指定工作空间中的所有要素类。可以通过通配符和过滤条件进一步筛选结果。 语法: python arcpy.ListFeatureClasses(wild_cardNone, feature_typeNone)• wild_card:用于筛选要素类名称的通配符,…...
C++学习笔记(三十七)——STL之搜索算法
STL 算法分类: 类别常见算法作用排序sort、stable_sort、partial_sort、nth_element等排序搜索find、find_if、count、count_if、binary_search等查找元素修改copy、replace、replace_if、swap、fill等修改容器内容删除remove、remove_if、unique等删除元素归约for…...
MySQL 9.3 正式发布!备份、用户管理与开发支持迎来革命性升级
开源数据库领域的标杆产品MySQL迎来重大更新——MySQL 9.3正式发布!作为企业级数据库的“扛把子”,此次版本更新聚焦备份效率、用户管理精细化、开发支持增强三大核心领域,同时在高可用性和性能优化上实现突破。以下为你逐一解读新版本的亮点…...

FPGA上实现YOLOv5的一般过程
在FPGA上实现YOLOv5 YOLO算法现在被工业界广泛的应用,虽说现在有很多的NPU供我们使用,但是我们为了自己去实现一个NPU所以在本文中去实现了一个可以在FPGA上运行的YOLOv5。 YOLOv5的开源代码链接为 https://github.com/ultralytics/yolov5 为了在FPGA中…...

4U带屏基于DSP/ARM+FPGA+AI的电力故障录波装置设计方案,支持全国产化
4U带屏DSP/ARMFPGAAI电力故障录波分析仪,支持国产化,含有CPU主控模块,96路模拟量采集,256路开关量,通讯扩展卡等#电力故障录波#4U带屏#新能源#电力监测 主要特点 1)是采用嵌入式图形系统,以及…...

数据库数据删除与修改实验
数据库数据删除与修改实验 在数据库原理的学习中,数据的删除与修改是核心操作技能。通过“删除修改数据”实验,我系统实践了 SQL 中 UPDATE 和 DELETE 语句的多种应用场景,从基础语法到复杂业务逻辑处理,积累了丰富的实战经验。本…...

【含文档+PPT+源码】基于SpringBoot+vue的疫苗接种系统的设计与实现
项目介绍 本课程演示的是一款 基于SpringBootvue的疫苗接种系统的设计与实现,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的 Java 学习者。 1.包含:项目源码、项目文档、数据库脚本、软件工具等所有资料 2.带你从零开始部署运行本套系…...
如何将IDP映射属性添加,到accountToken中 方便项目获取登录人信息
✅ 目标 你想要: 用户通过 IdP 登录(SAML 或 OAuth2)Keycloak 自动将 IdP 返回的属性(如:email、name、role 等)映射到用户账户中并把这些属性加入到用户登录返回的 Access Token 中,供业务系…...

项目自动化测试
一.设计测试用例(细致全面) 二.先引入所需要的pom.xml依赖 1.selenium依赖 2.webdrivermanager依赖 3.commons-io依赖 编写测试用例–按照页面对用例进行划分,每个页面是Java文件,页面下的所有用例统一管理 三.common包(放入公用包) 类1utils 可以调用driver对象,访问url …...

Python爬虫爬取图片并存储到MongoDB(注意:仅尝试存储一条空的示例数据到MongoDB,验证MongoDB的联通性)
以下是一个使用Python爬取图片并存储到MongoDB的示例实现,包含详细步骤说明: import requests from bs4 import BeautifulSoup from pymongo import MongoClient from datetime import datetime import os import re# 配置信息 mongoIP mongodb://root…...
Unocss 类名基操, tailwindcss 类名
这里只列出 unocss 的可实现类名,tailwindcss 可以拿去试试用 1. 父元素移入,子元素改样式 <!-- 必须是 group 类名 --> <div class"group"><div class"group-hover:color-red">Text</div> </div>2…...
Sharding-JDBC 系列专题 - 第七篇:Spring Boot 集成与 Sharding-Proxy 简介
Sharding-JDBC 系列专题 - 第七篇:Spring Boot 集成与 Sharding-Proxy 简介 本系列专题旨在帮助开发者全面掌握 Sharding-JDBC,一个轻量级的分布式数据库中间件。本篇作为系列的第七篇文章,将重点探讨 Sharding-JDBC 与 Spring Boot 的集成,以及 Sharding-Proxy 的基本概念…...
微服务划分的思考
为什么 微服务不是十全十美的,不是银弹,是什么原因导致必须要做微服务划分,是否有足够的动机支撑,是项目需要,还是领导的想法,公司层面是否有相应的规划。 拆分后的服务谁来维护,研发同学是否愿意参与 为什么,思考清楚了,接下来看还需要考虑怎么做 单体应用的不足…...

L1-1、Prompt 是什么?为什么它能“控制 AI”?
*Prompt 入门 L1-1 想象一下,你只需输入一句话,AI 就能自动为你写一篇文案、生成一份报告、甚至规划你的创业计划。这种“对话即编程”的背后魔法,就是 Prompt 的力量。 🔍 一、Prompt 的定义与由来 Prompt(提示词&am…...

TIM输入捕获知识部分
越往左,频率越高;越往右,频率越低。【越紧凑,相同时间,次数越多】 计算频率的方法:测评法、测周法、中界频率。 频率的定义:1s内出现了多少个重复的周期 测评法就是从频率的定义出发的&#…...
Ubuntu使用war包部署Jenkins并通过systemcl管理
目录 一、当前系统环境 二、安装Java 二、安装Jenkins 三、使用systemctl管理 一、当前系统环境 操作系统:ubuntu 24.04 Jenkins版本:2.506 格式:war JDK版本:OpenJDK_17 二、安装Java 1.下载jdk安装包 # wget下载 wget …...

PCB常见封装类型
1. 电阻、电容、电感封装 2. 二极管、三极管封 3. 排阻类器件(8脚、16脚)封装 4. SO类器件(间距有1.27、2.54mm等)封装 5. QFP类器件封装(四方扁平封装) 结构:引脚分布在封装的四个侧面&#…...
济南国网数字化培训班学习笔记-第二组-3节-电网工程建设项目部门
电网工程建设项目部 组成 监理项目部 履行监理合同,监理单位派驻:负责合同管理,审查,见证,旁站,巡视,验收,控制进度,安全,质量,协调各方 造价…...

【Linux】调试工具gdb的认识和使用指令介绍(图文详解)
目录 1、debug和release的知识 2、gdb的使用和常用指令介绍: (1)、windows下调试的功能: (2)、进入和退出: (3)、调试过程中的相关指令: 3、调试究竟是在…...
Vue3 ref与props
ref 属性 与 props 一、核心概念对比 特性ref (标签属性)props作用对象DOM 元素/组件实例组件间数据传递数据流向父组件访问子组件/DOM父组件 → 子组件响应性直接操作对象单向数据流(只读)使用场景获取 DOM/调用子组件方法组件参数传递Vue3 变化不再自…...

UML设计系列(9):开发过程中如何应用UML
传送门 UML设计系列(1):状态机图 UML设计系列(2):类图 UML设计系列(3):时序图 UML设计系列(4):用例图 UML设计系列(5):系统依赖图 UML设计系列(6):活动图 UML设计系列(7):UML设计阶段性总…...
Linux之安装配置Nginx
Linux系统下安装配置Nginx的详细步骤如下: 一、准备工作 系统环境:确保Linux系统已安装,并且具有网络连接(以便在线安装依赖或下载Nginx)。 安装依赖:Nginx依赖于一些开发库和工具,如gcc、pcr…...
【C++】STL之deque
deque Deque 的底层既不直接依赖 vector 也不依赖 list,而是结合了两者的思想,采用了一种分块(chunk)存储与动态指针数组(map)结合的结构。以下是详细分析: 1. 底层结构设计 Deque 的核心设计…...

模板方法模式:定义算法骨架的设计模式
模板方法模式:定义算法骨架的设计模式 一、模式核心:模板方法定义算法骨架,具体步骤延迟到子类实现 在软件开发中,经常会遇到这样的情况:某个算法的步骤是固定的,但具体步骤的实现可能因不同情况而有所不…...