详解Python 3.10 中的新功能和变化


Posted in Python onApril 28, 2021

随着最后一个alpha版发布,Python 3.10 的功能更改全面敲定!

现在,正是体验Python 3.10 新功能的理想时间!正如标题所言,本文将给大家分享Python 3.10中所有重要的功能和更改。

新功能1:联合运算符

在过去, |符号用于 "算术或"运算,例如:

print(0 | 0)
print(0 | 1)
print({1, 2} | {2, 3})

输出:

0
1
{1, 2, 3}

在Python 3.10中, |符号有的新语法,可以表示x类型 或 Y类型,以取代之前的typing.Union 完成类型注解

举个栗子:

函数的参数应该是一个int 或 str类型

旧的写法:

from typing import Union


def f(value: Union[int, str]) -> Union[int, str]:
    return value*2

新的写法:

def f(value: int | str) -> int | str:
    return value*2

这种新的语法也被作为isinstance() 和issubclass() 的第二个参数,用于类型判断

isinstance(1086, int | str)   # 10086是否为 int型 或 str型

新功能2: 多行上下文管理器

在过去,上下文管理器一般用于资源的自动获取和自动释放,利用打开文件时使用上下文管理器:

with open("test.txt", "w") as f:  # 自动打开和关闭文件
    f.write("hello, 我是三木")    #  对文件进行读写

如果要复制文件的话,需要打开源文件和目标文件,那么就需要2个上下文管理器,代码会写成这个样子:

with open("test.txt", "r") as f:  # 打开第一个文件
    with open("test_copy.txt", "w") as f_copy:  # 打开第二个文件
        content = f.read()  # 从第一个文件获取内容
        f_copy.write(content)  # 向第二个文件写入内容

在Python3.10中,可以将代码精简一下:

with (
    open("test.txt", "r") as f,  # 打开第一个文件
    open("test_copy.txt", "w") as f_copy,  # 打开第二个文件
):
    content = f.read()  # 从第一个文件获取内容
    f_copy.write(content)  # 向第二个文件写入内容

注意变化:

  1. with 只出现了1次
  2. 在同一个代码段,有2个上下文管理器f和 f_copy
  3. 这两个上下文管理可以交互

此外,还可以更加灵(sao)活(qi)的操作:

with (
    open("test.txt", "r", encoding="utf-8") as f,  # 打开第一个文件
    open("test_copy.txt", "w", encoding=f.encoding) as f_copy,  # 打开第二个文件
):
    content = f.read()  # 从第一个文件获取内容
    f_copy.write(content)  # 向第二个文件写入内容

注意细节:在第2个open中,使用了第一个open的结果 :f

新功能3: 结构模式匹配 (Structural Pattern Matching)

如果你熟悉或使用过php,Java或JavaScript等语言,可能见到switch语句,例如这样:

today = new Date().getDay();
switch () {
    case 0:
        day = "星期天";
        break;
    case 1:
        day = "星期一";
         break;
    case 2:
        day = "星期二";
         break;
    case 3:
        day = "星期三";
         break;
    case 4:
        day = "星期四";
         break;
    case 5:
        day = "星期五";
         break;
    case 6:
        day = "星期六";
}

简单来说:根据x的值,选择指定的case语句进行执行

过去,Python没有这样的语句,所以现在,有了!

today = 1
match  today:
    case 0:
        day = "星期天"
    case 1:
        day = "星期一"
    case 2:
        day = "星期二"
    case 3:
        day = "星期三"
    case 4:
        day = "星期四"
    case 5:
        day = "星期五"
    case 6:
        day = "星期六"
    case _:
        day = "别闹...一个星期只有七天"

print(day)

输出

星期一

如果将第一行改为today = 8,则输出

别闹...一个星期只有七天

注意:

  1. 匹配顺序是从上往下
  2. 找到一个匹配的case后,会停止,所以不需要向JavaScript一样写break语句
  3. 如果有多个符合条件的case,后面的case也不会有机会匹配到了
  4. 如果没有符合条件的匹配,则会执行case_,此_称之为通配符,通配符是可选的

关于结构匹配模式(Structural Pattern Matching),可以说是Python 3.10 重量级的新功能,它还有很多高级用法,值得专门一篇文章来进行介绍,这里就先不展开了。

总之,作为一个迟到了的“switch”,会在其他编程语言中的实践经验上进行改进,成符合Python一贯的风格:简单、灵活、强大。

新变化:性能改进

与所有最新的Python版本一样,Python 3.10也带来了一些性能改进。首先是str(),bytes()和bytearray()构造函数的优化,它们的速度应该提高30%~40%左右(来自 https://bugs.python.org/issue41334

~ $ ./python3.10 -m pyperf timeit -q --compare-to=python "str()"
Mean +- std dev: [python] 81.9 ns +- 4.5 ns -> [python3.10] 60.0 ns +- 1.9 ns: 1.36x faster (-27%)
~ $ ./python3.10 -m pyperf timeit -q --compare-to=python "bytes()"
Mean +- std dev: [python] 85.1 ns +- 2.2 ns -> [python3.10] 60.2 ns +- 2.3 ns: 1.41x faster (-29%)
~ $ ./python3.10 -m pyperf timeit -q --compare-to=python "bytearray()"
Mean +- std dev: [python] 93.5 ns +- 2.1 ns -> [python3.10] 73.1 ns +- 1.8 ns: 1.28x faster (-22%)

此外,还有多个Python核心模块正在进行持续的优化,让我们继续期待吧

新变化:zip支持长度检查

PEP 618:zip()函数现在具有一个可选strict标志,用于要求所有可迭代对象具有相等的长度

首先回顾一下zip函数的用法:

在一个迭代中,同时向多个序列读取内容,

可以将行变成列,列变成行,这类似于转置矩阵。

name_list = ['报警', '急救', '消防']
number_list = [110, 120, 119]

for i in zip(name_list, number_list):
    print(i)

输出

('报警', 110)
('急救', 120)
('消防', 119)

上面的例子有一个特点:name_list 和 number_list 长度是相同的,如果长度不同会怎么样呢?

name_list = ['报警', '急救', '消防', '查号']
number_list = [110, 120, 119]

for i in zip(name_list, number_list):
    print(i)

输出

('报警', 110)
('急救', 120)
('消防', 119)

注意:因为长度不同,所以最后一组结果查号是不会显示的,但是却没有任何提示,从结果来看,无法判断是否有遗漏的数据。

在Python 3.10,可以给zip()传递参数strict=True,对长度进行严格检查

for i in zip(name_list, number_list, strict=True):
    print(i)

输出

('报警', 110)
('急救', 120)
('消防', 119)
Traceback (most recent call last):
  File "C:\Users\san\PycharmProjects\py310\a.py", line 4, in <module>
    for i in zip(name_list, number_list, strict=True):
ValueError: zip() argument 2 is shorter than argument 1

注意: zip的第二个参数比第一个参数短,于是抛出异常

以上就是详解Python 3.10 中的新功能和变化的详细内容,更多关于Python 3.10 中的新功能和变化的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python修改MP3文件的方法
Jun 15 Python
python实现二维码扫码自动登录淘宝
Dec 27 Python
python扫描proxy并获取可用代理ip的实例
Aug 07 Python
基于python中staticmethod和classmethod的区别(详解)
Oct 24 Python
python 处理数字,把大于上限的数字置零实现方法
Jan 28 Python
Python读取YAML文件过程详解
Dec 30 Python
pymysql的简单封装代码实例
Jan 08 Python
Python random模块制作简易的四位数验证码
Feb 01 Python
基于matplotlib中ion()和ioff()的使用详解
Jun 16 Python
PyCharm 2020.1版安装破解注册码永久激活(激活到2089年)
Sep 24 Python
Python 实现键盘鼠标按键模拟
Nov 18 Python
python 实现图片特效处理
Apr 03 Python
Python基础之数据结构详解
Apr 28 #Python
Python基础详解之邮件处理
python实现黄金分割法的示例代码
Apr 28 #Python
Python 流媒体播放器的实现(基于VLC)
tensorflow+k-means聚类简单实现猫狗图像分类的方法
python实现三阶魔方还原的示例代码
python基于opencv批量生成验证码的示例
You might like
一拳超人中怪人协会钦定! S级别最强四人!
2020/03/02 日漫
PHP类的声明与实例化及构造方法与析构方法详解
2016/01/26 PHP
php事务回滚简单实现方法示例
2017/03/28 PHP
PHP文字转图片功能原理与实现方法分析
2017/08/31 PHP
JavaScript中的闭包原理分析
2010/03/08 Javascript
js判断选择的时间是否大于今天的代码
2013/08/20 Javascript
Jquery基础教程之DOM操作
2015/08/19 Javascript
jQuery实现可编辑的表格实例讲解(2)
2015/09/17 Javascript
jQuery实现的调整表格行tr上下顺序
2016/01/10 Javascript
Jq通过td获取同行其它列td的方法
2016/10/05 Javascript
AngularJS表单验证功能
2017/10/19 Javascript
jQuery中的$是什么意思及 $. 和 $().的区别
2018/04/20 jQuery
JavaScript中为事件指定处理程序的五种方式分析
2018/07/27 Javascript
vscode下vue项目中eslint的使用方法
2019/01/13 Javascript
node.js域名解析实现方法详解
2019/11/05 Javascript
vue使用swiper.js重叠轮播组建样式
2019/11/14 Javascript
[46:55]Ti4 冒泡赛第二轮 LGD vs C9
2014/07/14 DOTA
[57:29]Alliance vs KG 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/17 DOTA
[02:03]风行者至宝清风环佩外观展示
2020/09/05 DOTA
Python查找相似单词的方法
2015/03/05 Python
Python 私有函数的实例详解
2017/09/11 Python
浅谈Python使用Bottle来提供一个简单的web服务
2017/12/27 Python
python 移除字符串尾部的数字方法
2018/07/17 Python
关于不懂Chromedriver如何配置环境变量问题解决方法
2019/06/12 Python
keras读取训练好的模型参数并把参数赋值给其它模型详解
2020/06/15 Python
深入浅析css3 border-image边框图像详解
2015/11/24 HTML / CSS
浅析CSS3 用text-overflow解决文字排版问题
2020/10/28 HTML / CSS
浅谈html5 video 移动端填坑记
2018/01/15 HTML / CSS
韩国三大免税店之一:THE GRAND 中文免税店
2016/07/21 全球购物
亚马逊墨西哥站:Amazon.com.mx
2018/08/26 全球购物
英语系本科生个人求职信
2013/09/21 职场文书
大学生文员专业个人求职信范文
2014/01/05 职场文书
电子商务求职信
2014/06/15 职场文书
学生违反校规检讨书
2014/10/28 职场文书
《小蝌蚪找妈妈》教学反思
2016/02/23 职场文书
python处理json数据文件
2022/04/11 Python