Python3.10的一些新特性原理分析


Posted in Python onSeptember 15, 2021

Python 3.10.0a2 版本已经于 2020-11-04 发布,因此我们可以窥见 Python 3.10 的一些新特性。这些新特性很可能会改变未来的 Python 生态系统,使其朝着更明确,更易读的方向发展,同时保持我们熟知和喜欢的易用性。

Python3.10的一些新特性原理分析

 

 

PEP 602

 

1、类型注释的进一步扩展

3.9 版对 Python 中的类型提示和注释进行了大幅度修改和清理,类型提示这似乎是一种持续的趋势,在 3.10 中得到进一步扩展,目的很明显,是为了更好的可读性,无需看代码即可得知变量和函数返回值的类型。

延迟类型注释的执行

类型注释的运行通常被认为是在函数定义时执行,这意味着类型注释以自上而下的方式逐行进行检查。

尽管看起来合乎逻辑,但是这样做有两个问题:

  • 1、引用尚未定义的类型的类型提示(前向引用)将不起作用,必须以字符串形式表示。也就是说:假如 int 是自定义类型,我们需要编写 "int" 而不是编写 int 。
  • 2、这会减慢模块导入的速度,因为此时会执行类型提示。

因此,取而代之的是延迟类型注释,将类型注释将以字符串形式存储在__annotations__中,如果需要这些类型注释可以在运行时通过 typing.get_type_hints() 来解析,也可以通过inspect.signature() 来立即进行解析,这样的好处是可以先执行模块导入,允许前向引用,从而减少初始化时间。

新增类型注释联合操作符

3.10 通过 "|" 作为逻辑或操作符。在注释数据类型时,我们可以使用 | 作为或。例如,我们有一个预期为 int 或 float 的变量,可以写为 int | float ,如下所示:

def f(x: int | float) -> float:
    return x * 3.142
f(1)  # pass
f(1.5)  # pass
f('str')  # linter will show annotation error

也可以使用 typing 模块提供的关键字 Union,比如 Union[int, float]

TypeAlias 注释

回到前向引用问题,避免前向引用的常见解决方案是将它们编写为字符串。

但是,将类型写为字符串会在将这些类型分配给变量时引起问题,因为 Python 会假定我们的字符串文字类型注释只是一个字符串。

在通常使用类型注释的地方使用该类型注释变量将返回错误。例如:

MyType = "ClassName"  # ClassName is our type annotation
def foo() -> MyType:
    ...

在这里,我们试图将其 MyType 用作类型的别名 ,但是, MyType 它将被读取为字符串值,而不是类型别名。只要 ClassName 在代码的后面定义,这就是有效的。当前情况下,这将引发注释错误。

为了解决这个问题,添加了一种显式标识 MyType 为类型别名的方法 :

from typing_extensions import TypeAlias
MyType: TypeAlias = "ClassName"
def foo() -> MyType:
    ...
OR
MyType: TypeAlias = ClassName # if we have defined ClassName already
def foo() -> MyType:
    ...

这里说下,为什么类型很重要,尽管这当然不是一个巨大的变动,但是看到 Python 开发人员加倍努力以增强类型功能,这真是太酷了。Python 的优势在于其易用性和缺乏陡峭的学习曲线。原因之一是不需要在我们的代码中显式定义类型。

增强类型注释看起来似乎违反直觉,但是为开发人员 提供定义类型的选项 可以极大地提高代码库的可读性和可维护性。例如,从 Python transformers 库的源代码中可以看到以下说明:

Even without context, we can read this code and immediately grasp what data we should expect to be fed into these functions, classes, and methods — and exactly which datatypes we should be expecting to return.

In complex code bases (and even simple ones), type annotation can massively improve readability. Simultaneously, not everyone will want (or need) to use them — so an optional, exception-free functionality strikes a perfect balance.

意思是即使没有上下文,我们也可以阅读此代码,并立即掌握应将哪些数据期望输入到这些函数,类和方法中,以及确切地期望返回哪些数据类型。

但在复杂的代码库(甚至简单的代码库)中,类型注释可以大大提高可读性。同时,并不是每个人都希望(或需要)使用它们,因此,这是可选的。这种无异常的功能可以达到完美的平衡。

这些改进表明 Python 对类型注释功能的承诺,基于此,我们最喜欢的库和我们自己写的代码可以大大提示可阅读性,这会对 Python 生态系统产生长期的正面影响。

2、新增的函数及函数参数的变化

除了类型提示功能的扩展外,核心 Python 功能进行了一些更新,如下。

函数 zip() 增加 strict 参数

函数 zip() 增加 strict 参数,如果设置 strict = True,而传输的参数的长度不相等将会抛出异常,如下图所示:

Python3.10的一些新特性原理分析

新的 strict 参数不是盲目地截断不匹配的数据,而是使我们能够控制它的行为,这将使很多开发人员免于遭受麻烦。

新增整数的位计数器 int.bit_count()

此新方法使我们能够计算整数的二进制表示形式中 1 的个数,在某些场景下这个函数非常实用且高效。

Python3.10的一些新特性原理分析

上图中的结果即为整数以二进制位为 1 的个数:

0   = 00000000
1   = 00000001
2   = 00000010
3   = 00000011
10  = 00001010
11  = 00001011
12  = 00001100
100 = 01100100
101 = 01100101
102 = 01100110

字典的视图增加一个属性

字典类型的 3 个方法:dict.items()、dict.keys()、dict.values() 分别返回字典的 3 个视图,现在每个视图都增加来一个属性,叫 mapping,具体用法如下:

Python3.10的一些新特性原理分析

新的属性 mapping 的类型属于 types.MappingProxyType,是围绕原字典的一个属性,在任何视图上访问 mapping 属性,都将返回原字典。

现在就这些了,尽管我们距离 3.10 的开发时间表只有几个月的时间,但已经有很多有趣的更改,Python 的发展仍在继续,似乎还会为语言添加更多有趣的功能。

以上就是Python3.10的一些新特性原理分析的详细内容,更多关于Python3.10新特性的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Centos Python2 升级到Python3的简单实现
Jun 21 Python
Python语言描述连续子数组的最大和
Jan 04 Python
Django 实现下载文件功能的示例
Mar 06 Python
Selenium(Python web测试工具)基本用法详解
Aug 10 Python
django Serializer序列化使用方法详解
Oct 16 Python
Python编写带选项的命令行程序方法
Aug 13 Python
tensorflow 实现自定义梯度反向传播代码
Feb 10 Python
Python2 与Python3的版本区别实例分析
Mar 30 Python
如何基于Django实现上下文章跳转
Sep 16 Python
python输出国际象棋棋盘的实例分享
Nov 26 Python
python使用yaml 管理selenium元素的示例
Dec 01 Python
解决numpy和torch数据类型转化的问题
May 23 Python
一篇文章带你了解Python和Java的正则表达式对比
Sep 15 #Python
Python编程编写完善的命令行工具
Sep 15 #Python
python可视化之颜色映射详解
python的变量和简单数字类型详解
Sep 15 #Python
深入浅析Django MTV模式
python 进阶学习之python装饰器小结
Sep 04 #Python
自动在Windows中运行Python脚本并定时触发功能实现
Sep 04 #Python
You might like
php中取得文件的后缀名?
2012/02/20 PHP
php ZipArchive压缩函数详解实例
2013/11/06 PHP
搭建自己的PHP MVC框架详解
2017/08/16 PHP
JavaScript字符串对象substr方法入门实例(用于截取字符串)
2014/10/16 Javascript
js判断输入字符串是否为空、空格、null的方法总结
2016/06/14 Javascript
AngularJs  Creating Services详解及示例代码
2016/09/02 Javascript
jquery-mobile表单的创建方法详解
2016/11/23 Javascript
Bootstrap CSS组件之大屏幕展播
2016/12/17 Javascript
bootstrap PrintThis打印插件使用详解
2017/02/20 Javascript
Mongoose经常返回e11000 error的原因分析
2017/03/29 Javascript
纯js代码生成可搜索选择下拉列表的实例
2018/01/11 Javascript
小程序视频或音频自定义可拖拽进度条的示例代码
2018/09/30 Javascript
微信二次分享报错invalid signature问题及解决方法
2019/04/01 Javascript
jquery.pager.js分页实现详解
2019/07/29 jQuery
Python实现控制台进度条功能
2016/01/04 Python
详解python OpenCV学习笔记之直方图均衡化
2018/02/08 Python
python实现梯度下降算法
2020/03/24 Python
Django渲染Markdown文章目录的方法示例
2019/01/02 Python
pymongo中group by的操作方法教程
2019/03/22 Python
简单了解Python生成器是什么
2019/07/02 Python
Python统计分析模块statistics用法示例
2019/09/06 Python
Python TCPServer 多线程多客户端通信的实现
2019/12/31 Python
浅谈pytorch卷积核大小的设置对全连接神经元的影响
2020/01/10 Python
python实现图片转字符画
2021/02/19 Python
GANT英国官方网上商店:甘特衬衫
2018/02/06 全球购物
Ray-Ban雷朋西班牙官网:全球领先的太阳眼镜品牌
2018/11/28 全球购物
LUISAVIAROMA德国官网:时尚奢侈品牌购物网站
2020/11/12 全球购物
Ibatis中如何提高SQL Map的性能
2013/05/11 面试题
五一手机促销方案
2014/03/08 职场文书
工作失职检讨书(精华篇)
2014/10/15 职场文书
2014小学一年级班主任工作总结
2014/12/05 职场文书
音乐课外活动总结
2015/05/09 职场文书
大学生实习证明
2015/06/16 职场文书
新年寄语2016
2015/08/17 职场文书
小学三年级作文之写景
2019/11/05 职场文书
话题作文之呼唤
2019/12/18 职场文书