Python3.10新特性之match语句示例详解

作者:瑞0908 时间:2023-07-23 05:17:23 

在Python 3.10发布之前,Python是没有类似于其他语言中switch语句的,要实现类似的功能最简单的方法就是通过if ... elif ... else ...语句,但是这样毕竟不够优雅,不够“Pythonic”

更推荐的做法是通过字典(dict)实现。

通过字典间接实现 switch

想要通过字典来实现条件分支语句,首先我们需要定义一个字典,来表示不同case和返回值/函数之间的映射关系,然后再利用字典的特性,即可以实现类似于switch的功能。下面定义一个简单的函数,传入不同的case就会打印不同的内容,也可以将打印内容的语句替换成你想要执行的函数:

def switch(case):
   mapping = {
       1: "print('case 1')",
       2: "print('case 2')"
   }
   return eval(mapping[case])
switch(1)
运行结果:
case 1

可以看到,输出结果正是我们想要的“case 1”的结果。

在Python 3.10出现之前,我们更多的是通过上面这种字典映射的方式,来实现类似于switch语句的功能。但是伴随着Python 3.10的发布,Python也终于迎来了自己的'switch'语句,也就是接下来我们重点介绍的match语句。

Python 3.10 新特性—— match 语句,参考资料:Python 3.10增加了比switch更强大的match表达式在运行以下代码之前,请先确保自己的Python版本大于等于3.10。和其他语言一样,当变量num满足哪个case的条件时,就会执行该条件下的对应代码:

num = 5
match num:
   case 10:
       print('you lose')
   case 5:
       print('you win')
运行结果:
you win

当默认分支#当变量a不满足任意一个case条件时,如果我们没有对“其他“情况进行处理,那么是不会执行任何操作的。

下面的代码是不会有任何输出的,因为a不满足任意一个条件:

num = 3
match num:
   case 1:
       print('num 1')
   case 2:
       print('num 2')
无输出
如果想要对”其他“情况进行处理,那么写法如下:
num = 3
match num:
   case 1:
       print('num 1')
   case 2:
       print('num 2')
   case default:
       print('case default', default)
运行结果:
case default 3

可以看到,当变量a不符合任意一个条件时,就会运行到我们的default分支,同时会把变量值赋值给default变量。注意:这里的default仅仅只是一个变量名而已,并非规定写法,也可以使用其他变量名,例如x等。其作用就是在变量不符合任意一个分支条件时,将变量值赋值给该变量。

在case中使用元组

Python的match语句不仅支持数值类型的分支,也支持其他数据类型,例如元组(tuple)

a = (2, 4)
match a:
   case (1, 2):
       print('case 1')
   case (2, x):
       print('case 2', x)
运行结果:
case 2 4

可以看到,变量a在匹配到第二个分支条件时,还把元组的第二个元素值4赋值给了变量x。在case中使用判断语句#不仅如此,match语句还支持在分支条件中插入判断语句:

a = (2, 2)
flag = False
match a:
   case (1, 2):
       print('case 1')
   case (2, x) if flag:
       print('case 2', x)
   case default:
       print('case default', default)
运行结果:
case default (2, 2)

由于第二个分支条件中if flag为False,不符合条件,所以代码进入到最后一个分支条件中。

来源:https://segmentfault.com/a/1190000043378033

标签:Python3.10,特性,match,语句
0
投稿

猜你喜欢

  • JavaScript调试之console.log调试的一个小技巧分享

    2023-06-28 17:23:49
  • 排版自适应提升可访问性

    2009-04-08 12:47:00
  • SQL Server 总结复习(一)

    2012-10-07 11:04:02
  • 好的产品设计并非始于图片,而是对人的理解

    2009-08-02 20:25:00
  • 防止表单重复提交的巧妙方法

    2009-03-09 18:32:00
  • 详细讲解SQL Server数据库的文件恢复技术

    2009-01-15 12:54:00
  • asp使用模板生成静态页面方法详解

    2007-09-24 12:29:00
  • MySQL应用技巧之存取权限

    2010-08-08 09:10:00
  • asp详解session的用法

    2007-09-07 10:22:00
  • 聚族索引、非聚族索引、组合索引的含义和用途

    2010-07-02 21:51:00
  • ThinkPHP5中如何使用redis

    2023-06-13 01:09:10
  • ASP判断一个字符串中只包含字母和数字

    2008-08-08 12:12:00
  • ASP连接MySQL数据库代码示例

    2010-03-14 11:24:00
  • MySQL表设计优化与索引 (八)

    2010-10-25 19:46:00
  • XML与HTML的结合(下)

    2008-09-05 17:20:00
  • Linux 创建oracle数据库的详细过程

    2023-07-14 15:59:09
  • asp的access数据库备份 压缩 恢复及清理数据库函数

    2008-10-31 12:36:00
  • 用Dreamweaver MX巧妙格式化表格

    2008-03-18 16:39:00
  • ASP正则表达式技巧

    2011-04-10 11:00:00
  • SQL提高查询效率之Like篇

    2011-10-01 09:36:42
  • asp之家 网络编程 m.aspxhome.com