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

相关文章

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

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的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版