case/switch 语句的 Python 等价物是什么?

2023-09-02Python开发问题
2

本文介绍了case/switch 语句的 Python 等价物是什么?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

是否有 Python 等效的 case 语句,例如 VB.NET 或 C# 中可用的示例?

Is there a Python equivalent for the case statement such as the examples available in VB.NET or C#?

推荐答案

Python 3.10 及以上版本

在 Python 3.10 中,他们引入了模式匹配.

Python 文档中的示例:

def http_error(status):
    match status:
        case 400:
            return "Bad request"
        case 404:
            return "Not found"
        case 418:
            return "I'm a teapot"
        case _:
            return "Something's wrong with the internet"

在 Python 3.10 之前

虽然官方文档很高兴不提供开关,但我看到了一个使用字典的解决方案.

Before Python 3.10

While the official documentation are happy not to provide switch, I have seen a solution using dictionaries.

例如:

# define the function blocks
def zero():
    print "You typed zero.
"

def sqr():
    print "n is a perfect square
"

def even():
    print "n is an even number
"

def prime():
    print "n is a prime number
"

# map the inputs to the function blocks
options = {0 : zero,
           1 : sqr,
           4 : sqr,
           9 : sqr,
           2 : even,
           3 : prime,
           5 : prime,
           7 : prime,
}

然后调用等效的 switch 块:

Then the equivalent switch block is invoked:

options[num]()

如果您严重依赖失败,这将开始崩溃.

This begins to fall apart if you heavily depend on fall through.

这篇关于case/switch 语句的 Python 等价物是什么?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

The End

相关推荐

在xarray中按单个维度的多个坐标分组
groupby multiple coords along a single dimension in xarray(在xarray中按单个维度的多个坐标分组)...
2024-08-22 Python开发问题
15

Pandas中的GROUP BY AND SUM不丢失列
Group by and Sum in Pandas without losing columns(Pandas中的GROUP BY AND SUM不丢失列)...
2024-08-22 Python开发问题
17

GROUP BY+新列+基于条件的前一行抓取值
Group by + New Column + Grab value former row based on conditionals(GROUP BY+新列+基于条件的前一行抓取值)...
2024-08-22 Python开发问题
18

PANDA中的Groupby算法和插值算法
Groupby and interpolate in Pandas(PANDA中的Groupby算法和插值算法)...
2024-08-22 Python开发问题
11

PANAS-基于列对行进行分组,并将NaN替换为非空值
Pandas - Group Rows based on a column and replace NaN with non-null values(PANAS-基于列对行进行分组,并将NaN替换为非空值)...
2024-08-22 Python开发问题
10

按10分钟间隔对 pandas 数据帧进行分组
Grouping pandas DataFrame by 10 minute intervals(按10分钟间隔对 pandas 数据帧进行分组)...
2024-08-22 Python开发问题
11