python之流程控制语句match-case详解

2025-03-19 02:50

本文主要是介绍python之流程控制语句match-case详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《python之流程控制语句match-case详解》:本文主要介绍python之流程控制语句match-case使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐...

match-case 语法详解与实战

match-casepython 3.10+ 引入的模式匹配语法,可替代传统的 if-elif-else 链,支持复杂数据解构和条件组合。

以下是 6 个核心使用场景与代码案例:

一、基础值匹配(类似 switch-case)

# 匹配 HTTP 状态码
status_code = 418

match status_codehttp://www.chinasem.cn:
    case 200:
        print("✅ Success")
    case 301 | 302 | 307:
        print("↪️ Redirect")
    case 400 | 401 | 403:
        print("❌ Client Error")
    case 500:
        print(" Server Error")
    case _:
        print(f"Unknown status: {status_code}")
        
输出:Unknown status: 418

二、数据结构解构匹配

场景1:列表解构

def parse_command(cmd: list):
    match cmhttp://www.chinasem.cnd:
        case ["start", *args]:
            print(f" 启动服务,参数: {args}")
        case ["stop", service_name]:
            print(f" 停止服务: {service_name}")
        case ["restart"]:
            print(" 重启服务")
        case _:
            print("⚠️ 无效指令")

parse_command(["start", "--port=8080"])  #  启动服务,参数: ['--port=8080']
parse_command(["stop", "nginx"])         #  停止服务: nginx

场景2:字典解构

user_data = {
    "name": "John",
    "age": 25,
    "address": {"city": "New York", "zip": "10001"}
}

match user_data:
    case {"name": str(name), "age": int(age), "address": {"city": city}}:
        print(f" {name} ({age}岁) 来自 {city}")
    case {"name": _, "age": int(age)} if age < 0:
        print("⛔ 年龄不能为负数")
    case _:
        print("❓ 数据格式错误")

# 输出: John (25岁) 来自 New York

三、类实例模式匹配

class Vector:
    def __init__(self, x, y, z=0):
        self.x = x
        self.y = y
        self.z = z

def analyze_vector(vec):
    match vec:
        case Vector(0, 0, 0):
            print("⭕ 零向量")
        case Vector(x=0, y=0):
            print(" Z轴向量")
        case Vector(x, y, z) if x == y == z:
            print(" 立方体对角线")
        case Vector(_, _, z) if z != 0:
            print(f" 三维向量 (Z=js{z})")
        case _:
            print(" 普通二维向量")

analyze_vector(Vector(0, 0, 0))   # ⭕ 零向量
analyze_vector(Vector(2, 2, 2))   #  立方体对角线

四、带守卫条件的高级匹配

def process_transaction(tx):
    match tx:
        case {"type": "deposit", "amount": amt} if amt > 0:
            print(f" 存入 {amt} 元")
        case {"type": "withdraw", "amount": amt, "balance": bal} if amt <= bal:
            print(f" 取出 {amt} 元")
        case {"type": "withdraw", "amount": amt}:
            print(f"⛔ 余额不足,尝试取出 {amt} 元")
        case {"type": _}:
     js       print("❌ 无效交易类型")

process_transaction({"type": "withdraw", "amount": 500, "balance": 1000})
# 输出: 取出 500 元

五、类型验证与组合匹配

def handle_data(data):
    match data:
        case int(n) if n % 2 == 0:
            print(f" 偶数: {n}")
        case float(f) if f > 100.0:
            print(f" 大额浮点数: {f:.2f}")
        case str(s) if len(s) > 50:
            print(" 长文本(已截断):", s[:50] + "...")
        case list([int(x), *rest]):
            print(f" 整数列表,首元素: {x}, 长度: {len(rest)+1}")
        case _:
            print("❓ 未知数据类型")

handle_data(42)            #  偶数: 42
handle_data([10, 20, 30])  #  整数列表,首元素: 10, 长度: 3

六、协议解析实战案例

def parse_packet(packet: bytes):
    match packet:
        case b'\x08\x00' | b'\x08\x01':
            print(" ICMP 数据包")
        case b'\x45' + payload:
            print(f" IPv4 数据包,载荷长度: {len(payload)}")
        case [version, _, *rest] if version >> 4 == 6:
            print(" IPv6 数据包")
        case _:China编程
            print("❌ 未知协议")

parse_packet(b'\x45\x00\x00\x1c\x00\x01\x00\x00\x40')  #  IPv4 数据包...

使用注意事项:

  • 版本要求:仅支持 Python 3.10+
  • 匹配顺序:按代码顺序执行,首个匹配成功即终止
  • 通配符 _:必须放在最后,匹配所有未处理情况
  • 性能优化:复杂模式匹配可能影响性能,避免深层嵌套

与传统写法对比:

  • 场景 match-case 写法 if-elif 传统写法
  • 多条件值匹配 使用 运算符简洁组合 需要重复 or 连接条件
  • 字典嵌套解构 直接提取多级字段 多层 get( ) 检查和类型验证
  • 类属性检查 直接匹配对象属性 需要 isinstance() 和属性访问
  • 组合条件 case + if 守卫条件 需要复杂布尔表达式
  • 通过合理使用 match-case,可以使代码更简洁易读,特别适用于:协议解析、API响应处理、复杂业务规则判断等场景。建议搭配类型提示(Type Hints)使用效果更佳!

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持China编程(www.chinasem.cn)。

这篇关于python之流程控制语句match-case详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

HTML5 搜索框Search Box详解

《HTML5搜索框SearchBox详解》HTML5的搜索框是一个强大的工具,能够有效提升用户体验,通过结合自动补全功能和适当的样式,可以创建出既美观又实用的搜索界面,这篇文章给大家介绍HTML5... html5 搜索框(Search Box)详解搜索框是一个用于输入查询内容的控件,通常用于网站或应用程

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

Python虚拟环境与Conda使用指南分享

《Python虚拟环境与Conda使用指南分享》:本文主要介绍Python虚拟环境与Conda使用指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、python 虚拟环境概述1.1 什么是虚拟环境1.2 为什么需要虚拟环境二、Python 内置的虚拟环境工具

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Python pip下载包及所有依赖到指定文件夹的步骤说明

《Pythonpip下载包及所有依赖到指定文件夹的步骤说明》为了方便开发和部署,我们常常需要将Python项目所依赖的第三方包导出到本地文件夹中,:本文主要介绍Pythonpip下载包及所有依... 目录步骤说明命令格式示例参数说明离线安装方法注意事项总结要使用pip下载包及其所有依赖到指定文件夹,请按照以

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1

Python包管理工具核心指令uvx举例详细解析

《Python包管理工具核心指令uvx举例详细解析》:本文主要介绍Python包管理工具核心指令uvx的相关资料,uvx是uv工具链中用于临时运行Python命令行工具的高效执行器,依托Rust实... 目录一、uvx 的定位与核心功能二、uvx 的典型应用场景三、uvx 与传统工具对比四、uvx 的技术实

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可