Python `for` 循环完全指南(含用例)

Python for 循环完全指南

for 循环是 Python 中最核心的迭代结构,它能够遍历任何可迭代对象(如列表、元组、字符串、字典、集合、文件对象等),并对每个元素执行指定的操作。与其他语言(如 C 的 for (i=0; i<n; i++))不同,Python 的 for 更接近“foreach”风格,专注于遍历序列或集合中的元素,语法简洁且功能强大。

本文将系统讲解 for 循环的基本语法、常用场景,并通过杨辉三角打印数独求解器两个综合案例,展示 for 循环在实际编程中的灵活应用。


1. 基本语法与常用场景

1.1 语法结构

for 变量 in 可迭代对象: 循环体 else:# 可选,当循环正常结束(没有被 break 中断)时执行 语句块 
  • 变量:每次迭代从可迭代对象中取出一个元素赋值给该变量。
  • 可迭代对象:包括列表、元组、字符串、字典、集合、range 对象、文件对象、生成器等。
  • 循环体:需要重复执行的代码块,注意缩进。
  • else 子句:可选,当循环未被 break 终止时执行。

1.2 常用遍历场景

遍历列表
fruits =["苹果","香蕉","橙子"]for fruit in fruits:print(f"我喜欢吃 {fruit}")# 输出:# 我喜欢吃 苹果# 我喜欢吃 香蕉# 我喜欢吃 橙子
遍历元组
coordinates =(10,20,30)for coord in coordinates:print(f"坐标值: {coord}")
遍历字符串(字符序列)
message ="Python"for char in message:print(char, end="-")# 输出:P-y-t-h-o-n-
遍历字典
person ={"name":"张三","age":30,"city":"北京"}# 遍历键(默认)for key in person:print(key)# 输出:name age city# 遍历值for value in person.values():print(value)# 输出:张三 30 北京# 同时遍历键和值for key, value in person.items():print(f"{key}: {value}")
使用 range() 生成数字序列
# 生成 0 到 4for i inrange(5):print(i, end=" ")# 输出:0 1 2 3 4# 生成 2 到 8,步长为 2for i inrange(2,9,2):print(i, end=" ")# 输出:2 4 6 8# 使用索引遍历列表 fruits =["苹果","香蕉","橙子"]for i inrange(len(fruits)):print(f"索引 {i}: {fruits[i]}")
使用 enumerate() 同时获取索引和元素
fruits =["苹果","香蕉","橙子"]for index, fruit inenumerate(fruits):print(f"索引 {index}: {fruit}")
使用 zip() 并行遍历多个可迭代对象
names =["张三","李四","王五"] scores =[85,92,78]for name, score inzip(names, scores):print(f"{name} 的分数是 {score}")
循环控制:breakcontinue
# 查找第一个偶数 numbers =[1,3,5,8,9,10]for num in numbers:if num %2==0:print(f"找到偶数: {num}")break# 立即退出循环# 跳过偶数,打印奇数for num in numbers:if num %2==0:continue# 跳过本次循环剩余部分print(num)
for...else 结构
# 检查列表中是否有偶数 numbers =[1,3,5,7,9]for num in numbers:if num %2==0:print("发现偶数!")breakelse:print("没有偶数。")# 因为循环未被 break,所以执行
列表推导式(简洁的 for 循环)
# 生成 0~9 的平方列表 squares =[x**2for x inrange(10)]print(squares)# 输出:[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]# 带条件的推导式(只保留偶数) even_squares =[x**2for x inrange(10)if x %2==0]print(even_squares)# 输出:[0, 4, 16, 36, 64]
遍历文件对象
withopen("example.txt","r", encoding="utf-8")as f:for line in f:print(line, end="")# 逐行打印

2. 案例一:打印杨辉三角(数字金字塔)

杨辉三角(Pascal’s Triangle)是一个经典的数学图形,每一行由组合数构成,满足:

  • 第 n 行有 n+1 个数字(行号从 0 开始)。
  • 首尾数字为 1。
  • 内部数字等于上一行相邻两数之和:triangle[i][j] = triangle[i-1][j-1] + triangle[i-1][j]

2.1 使用组合数公式(math.comb

import math defprint_pascal_comb(n):"""打印 n 行的杨辉三角,使用组合数公式"""for row inrange(n):# 打印前导空格,使三角形居中print(" "*(n - row -1)*3, end="")# 每个数字占3位,乘3对齐for col inrange(row +1): num = math.comb(row, col)print(f"{num:3}", end=" ")print() print_pascal_comb(6)

输出:

 1 1 1 1 2 1 1 3 3 1 1 4 6 4 1 1 5 10 10 5 1 

for 循环点睛:

  • 外层 for row 控制行数。
  • 内层 for col 遍历每一行的元素,用组合数计算值。
  • 前导空格数量随行数递减,实现居中效果。

2.2 使用迭代生成(递推关系)

defprint_pascal_iter(rows):"""打印 rows 行的杨辉三角,使用迭代生成""" triangle =[]# 存储整个三角形for i inrange(rows): row =[1]*(i +1)# 初始化为全1,首尾已正确for j inrange(1, i):# 从第2个到倒数第2个 row[j]= triangle[i-1][j-1]+ triangle[i-1][j] triangle.append(row)# 打印三角形 max_width =len(str(max(triangle[-1])))# 最大数字宽度for i, row inenumerate(triangle):print(" "*(rows - i -1)*(max_width +1), end="")for num in row:print(f"{num:{max_width}d}", end=" ")print() print_pascal_iter(8)

输出:

 1 1 1 1 2 1 1 3 3 1 1 4 6 4 1 1 5 10 10 5 1 1 6 15 20 15 6 1 1 7 21 35 35 21 7 1 

for 循环点睛:

  • 外层 for i 逐行构建。
  • 内层 for j 根据上一行计算当前行中间值。
  • 打印部分再次使用嵌套 for 控制对齐。

3. 案例二:数独求解器(回溯算法)

数独是 9×9 的网格,每行、每列和每个 3×3 宫(共 9 个)必须包含 1-9 各一次。我们将用 for 循环实现回溯法求解。

3.1 数独的表示

空白格用 0 表示,示例数独:

5 3 . | . 7 . | . . . 6 . . | 1 9 5 | . . . . 9 8 | . . . | . 6 . ------+-------+------ 8 . . | . 6 . | . . 3 4 . . | 8 . 3 | . . 1 7 . . | . 2 . | . . 6 ------+-------+------ . 6 . | . . . | 2 8 . . . . | 4 1 9 | . . 5 . . . | . 8 . | . 7 9 

3.2 合法性检查函数

defis_valid(board, row, col, num):"""检查在 (row, col) 处填入 num 是否合法"""# 检查行for j inrange(9):if board[row][j]== num:returnFalse# 检查列for i inrange(9):if board[i][col]== num:returnFalse# 检查所在 3x3 宫 start_row, start_col =3*(row //3),3*(col //3)for i inrange(start_row, start_row +3):for j inrange(start_col, start_col +3):if board[i][j]== num:returnFalsereturnTrue

for 循环点睛:

  • 三个独立的 for 循环分别扫描行、列、宫。
  • 宫内使用双重 for 遍历 3×3 区域。

3.3 回溯求解函数

defsolve_sudoku(board):"""使用回溯法求解数独(修改原 board),返回是否找到解"""for i inrange(9):for j inrange(9):if board[i][j]==0:# 找到空白格for num inrange(1,10):# 尝试 1-9if is_valid(board, i, j, num): board[i][j]= num if solve_sudoku(board):# 递归求解剩余部分returnTrue board[i][j]=0# 回溯returnFalse# 无解,回溯returnTrue# 无空白格,求解完成

for 循环点睛:

  • 双重 for 遍历整个棋盘,定位空白格。
  • 内层 for num 枚举所有候选数字,依次尝试。
  • 递归调用自身继续求解,利用 for 循环实现深度优先搜索。

3.4 打印函数

defprint_sudoku(board):"""美观打印数独棋盘"""for i inrange(9):if i %3==0and i !=0:print("-"*21)# 每三行打印横线for j inrange(9):if j %3==0and j !=0:print("|", end=" ")# 每三列打印竖线print(board[i][j]if board[i][j]!=0else".", end=" ")print()

for 循环点睛:

  • 外层 for i 控制行,内层 for j 控制列。
  • 利用 % 运算符在适当位置添加分隔符,使棋盘清晰。

3.5 完整测试

# 定义数独(同上) sudoku =[[5,3,0,0,7,0,0,0,0],[6,0,0,1,9,5,0,0,0],[0,9,8,0,0,0,0,6,0],[8,0,0,0,6,0,0,0,3],[4,0,0,8,0,3,0,0,1],[7,0,0,0,2,0,0,0,6],[0,6,0,0,0,0,2,8,0],[0,0,0,4,1,9,0,0,5],[0,0,0,0,8,0,0,7,9]]print("原始数独:") print_sudoku(sudoku)if solve_sudoku(sudoku):print("\n解出的数独:") print_sudoku(sudoku)else:print("无解")

输出(节选):

原始数独: 5 3 . | . 7 . | . . . 6 . . | 1 9 5 | . . . . 9 8 | . . . | . 6 . ------+-------+------ 8 . . | . 6 . | . . 3 4 . . | 8 . 3 | . . 1 7 . . | . 2 . | . . 6 ------+-------+------ . 6 . | . . . | 2 8 . . . . | 4 1 9 | . . 5 . . . | . 8 . | . 7 9 解出的数独: 5 3 4 | 6 7 8 | 9 1 2 6 7 2 | 1 9 5 | 3 4 8 1 9 8 | 3 4 2 | 5 6 7 ------+-------+------ 8 5 9 | 7 6 1 | 4 2 3 4 2 6 | 8 5 3 | 7 9 1 7 1 3 | 9 2 4 | 8 5 6 ------+-------+------ 9 6 1 | 5 3 7 | 2 8 4 2 8 7 | 4 1 9 | 6 3 5 3 4 5 | 2 8 6 | 1 7 9 

4. 总结

通过上述案例,我们可以看到 for 循环在 Python 编程中的核心地位:

  • 遍历数据:无论是简单的列表、字典,还是复杂的二维网格,for 循环都能轻松遍历。
  • 枚举尝试:在数独求解中,for num in range(1,10) 枚举所有可能数字,是回溯算法的基石。
  • 模式生成:杨辉三角的每一行都通过 for 循环递推构建,体现了循环与数学规律的结合。
  • 格式化输出:利用 for 循环控制打印格式,可以输出美观的图形(如数独棋盘、杨辉三角)。

掌握 for 循环,是通往 Python 编程高手的重要一步。希望本文的讲解和案例能帮助你更深入地理解并灵活运用这一强大的工具。

Read more

IDEA 创建 Spring Boot Web 项目完整教程

一、新建 Spring Boot 项目 1. 打开新建项目窗口 * 打开 IntelliJ IDEA → 点击 新建项目(或从欢迎页选择 New Project) * 在左侧生成器中选择 Spring Boot *          截图如下 * 选项填写内容说明服务器 URLstart.spring.ioSpring 官方初始化地址名称demo项目名位置D:\idea项目存放路径(建议不要含中文 / 空格)语言Java开发语言类型Maven项目构建工具组org.example项目组织标识工件demo项目模块名软件包名称com.example.demo根包名JDK21 Oracle OpenJDK 21.0.8你的 JDK 版本Java17源码兼容版本(Spring Boot 4.0.3 推荐 Java 17+)打包Jar可执行 Jar 包(Spring

By Ne0inhk
Flutter 三方库 shelf_web_socket 的鸿蒙化适配指南 - 实现具备高性能全双工长连接与协议协商能力的端侧服务端架构、支持分布式实时信令与多端协同实战

Flutter 三方库 shelf_web_socket 的鸿蒙化适配指南 - 实现具备高性能全双工长连接与协议协商能力的端侧服务端架构、支持分布式实时信令与多端协同实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 shelf_web_socket 的鸿蒙化适配指南 - 实现具备高性能全双工长连接与协议协商能力的端侧服务端架构、支持分布式实时信令与多端协同实战 前言 在进行 Flutter for OpenHarmony 开发时,当我们的鸿蒙应用需要充当“控制中心”角色(如控制智能家居、开启本地调试服务或实现 P2P 实时对抗脚本时),如何在端侧直接拉起一个支持 WebSocket 协议的高性能微服务端?shelf_web_socket 是针对 shelf 后端框架封装的一款官方级 WebSocket 处理器。本文将探讨如何在鸿蒙端构建极致、透明的长连接交互引擎。 一、原直观解析 / 概念介绍 1.1 基础原理 该库本质上是一个 shelf 处理函数(Handler)

By Ne0inhk
Flutter for OpenHarmony: Flutter 三方库 fixnum 解决鸿蒙 Web 与原生端 64 位大整数精度失真难题(精准计算护卫)

Flutter for OpenHarmony: Flutter 三方库 fixnum 解决鸿蒙 Web 与原生端 64 位大整数精度失真难题(精准计算护卫)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 在进行 OpenHarmony 的跨平台开发时,你可能会遇到一个诡异的 Bug:同样的 64 位长整数(如 Int64),在鸿蒙原生(Native)模式下运行正常,但编译为 Flutter Web 模式在浏览器运行时,数值却发生了精度漂移或溢出。 1. 产生原因:JavaScript 原生的数字类型实质上是 64 位浮点数,它能安全表示的最大整数只有 53 位( 2 53 − 1 2^{53}-1 253−1)。 2. 后果:大额订单 ID、高精度的金融分位值、或是底层硬件的 64 位地址位,在

By Ne0inhk

openclaw web UI 无法访问 not found

## 问题解决总结 根本原因 :Gateway 的 resolveControlUiRootSync 函数在自动查找控制 UI 目录时,没有包含 node_modules/openclaw/dist/control-ui 作为候选路径。手动指定相对路径时,可能因为工作目录解析问题无法正确找到目录。 最终解决方案 : 1. 将控制 UI 文件从 node_modules/openclaw/dist/control-ui 复制到项目根目录       E:\你实际的目录\control-ui       (建立一个英文,且没有符号的目录,“-”和“_",会引起混淆) 2. 在配置文件中使用绝对路径指定 controlUi.root: "E:\\你实际的目录\\control-ui" 编辑 openclaw.json "

By Ne0inhk