Python3.9新版本国庆假期偷偷上线!一文看完新版本功能
off999 2024-09-26 16:16 22 浏览 0 评论
10月5日,当我们还在享受愉快的国庆假期时,Python3.9 的完整版本出来了!
很明显,这个版本标志着 Python 从旧路线进化到一条新路径的转折点。
本文我们将重点介绍以下内容:
1.Python 新路径
- 解析器更改
- 开发周期
2.新功能
- 类型提示
- 字符串方法
- 词典联合
接下来让我们探索这些新功能,来了解 Python 的未来走向。
一.Python 的新路径
此更新有两个重大变化,我们不会看到任何直接影响,但我们将开始注意到 Python 作为一种语言的略有不同的演变。
简而言之,这可以归结为:
- Python 的解析器限制
- 更小但更频繁的版本
1.LL(1) 和 PEG
大约30年前吉多·范·罗森写了pgen。这是最早为Python编写的代码之一,直到今天,它仍被用作Python的解析器。
Pgen 使用基于 LL(1) 的语法变体。这意味着我们的解析器从上到下,从左到右读取代码,只需提前一个标记。
这基本上意味着 Python 开发是有限的,因为:
- 提前一个标记限制了语法规则的表达能力。
- Python 已经包含非 LL(1) 语法,这意味着当前解析器使用大量解决方法,使过程过于复杂。
- 即使有这些解决方法,也只能有这么多可能。规则可以弯曲,但不能违反。
对于 LL(1),特定的左递归语法可能会导致解析树中的无限循环,导致堆栈溢出。
基于 LL(1) 的解析器的这些属性限制了 Python 中可能实现的值。
Python 3.9 已经突破了这些限制,这要归功于 PEP 617 中概述的闪亮登场的新 PEG 解析器。
但是我们不会马上注意到这一点。因为在 Python 3.10 之前不会对利用新解析器进行更改。但在那之后,Python将从LL(1)的束缚中被释放。
2.开发周期
在3.9之前,Python的版本发布计划为18个月。现在,我们看到的是12个月的发布时间表[PEP602]。
现在我们将每年看到一次Python的新版本,而不是一年半一次。这意味着:
- 就新功能而言,版本发行的规模更小。
- 虽然更改是循序渐进的,但通过更快地发布新功能和修复BUG还是很好的。
- 更加一致的发布日历。从现在开始,我们只需要知道每年10月Python新版本就会发布!
因此从本质上讲,我们将来会看到12个月一次的小改,而不是18个月一次的大改。同时,开发速度估计会保持不变,大家不需要担心大改带来的版本不适应了。
二.新功能
除了这些背后你看不到的变化外,我们再来看看Python的新功能!
1.类型提示
早在2008年,Python 3就引入了函数注释--类型提示的前身。它不是特别强大,但它是一个开始。
在此之后,随着时间的推移添加了更多功能。但现在,3.9 将所有这些不同的功能与整洁的新语法结合在一起,以生成 Python 类型提示的最新开发。
我们可以轻松地指定变量的预期数据类型。如果我们写了一些没有意义的东西(比如我们把一个字符串传递给一个整数),那么我们的编辑器就会标记这个问题。
虽然不会引发错误,但在使用复杂的代码库时,这个功能还是非常有用的。让我们来看看新的语法。
在 Python 中,用+添加两个字符串是绝对有效的。因此,在这个add_int函数接收两个字符串的情况下,不会引发错误。
使用新的类型提示功能,我们只需在函数定义中的参数中添加:int,编辑器就会立即注意到错误。
我们也可以使用 ->type 语法来确定函数输出的值的类型。
我们也不局限于简单的预定义类型!
2.字符串方法
可能看起来没有什么华丽的变化,但是该方法经常被使用。我们有两种删除字符串前缀和后缀的新方法:
"foo bar".removeprefix("fo")
[Out]: 'o bar'
"foo bar".removesuffix("ar")
[Out]: 'foo b'
3.字典联合
我们现在有两个新运算符来执行字典联合。
第一个是合并运算符 | :
a = {1: 'a', 2: 'b', 3: 'c'}
b = {4: 'd', 5: 'e'}
c = a | b
print(c)
[Out]: {1: 'a', 2: 'b', 3: 'c', 4: 'd', 5: 'e'}
以及 update 运算符,它执行就地合并的操作:
a = {1: 'a', 2: 'b', 3: 'c'}
b = {4: 'd', 5: 'e'}
a |= b
print(a)
[Out]: {1: 'a', 2: 'b', 3: 'c', 4: 'd', 5: 'e'}
此外,在Python3.9中,还更新了一些其他的小功能:
- 在日期时间中支持 IANA 时区。zoneinfo 模块是为支持IANA时区数据库而创建的。对IANA时区数据库的这种支持已添加到标准库中。
- 参数cancel_futures被添加到 concurrent.futures.Executor.shutdown() 中
- 异步和多处理改进
- 一致的包导入错误
- 随机字节生成
- 字符串替换函数修复
详细的功能,大家记得去查看官方文档哈~
Python未来值得期待
Python作为一种编程语言,未来还是有很多值得期待的地方。从3.9版本的发布,我们可以看出这门语言是如何随着新的发布时间表和解析器而演变的,希望Python能往更好的方向发展吧。
相关推荐
- python入门到脱坑经典案例—清空列表
-
在Python中,清空列表是一个基础但重要的操作。clear()方法是最直接的方式,但还有其他方法也可以实现相同效果。以下是详细说明:1.使用clear()方法(Python3.3+推荐)...
- python中元组,列表,字典,集合删除项目方式的归纳
-
九三,君子终日乾乾,夕惕若,厉无咎。在使用python过程中会经常遇到这四种集合数据类型,今天就对这四种集合数据类型中删除项目的操作做个总结性的归纳。列表(List)是一种有序和可更改的集合。允许重复...
- Linux 下海量文件删除方法效率对比,最慢的竟然是 rm
-
Linux下海量文件删除方法效率对比,本次参赛选手一共6位,分别是:rm、find、findwithdelete、rsync、Python、Perl.首先建立50万个文件$testfor...
- 数据结构与算法——链式存储(链表)的插入及删除,
-
持续分享嵌入式技术,操作系统,算法,c语言/python等,欢迎小友关注支持上篇文章我们讲述了链表的基本概念及一些查找遍历的方法,本篇我们主要将一下链表的插入删除操作,以及采用堆栈方式如何创建链表。链...
- Python自动化:openpyxl写入数据,插入删除行列等基础操作
-
importopenpyxlwb=openpyxl.load_workbook("example1.xlsx")sh=wb['Sheet1']写入数据#...
- 在Linux下软件的安装与卸载(linux里的程序的安装与卸载命令)
-
通过apt安装/协助软件apt是AdvancedPackagingTool,是Linux下的一款安装包管理工具可以在终端中方便的安装/卸载/更新软件包命令使用格式:安装软件:sudoapt...
- Python 批量卸载关联包 pip-autoremove
-
pip工具在安装扩展包的时候会自动安装依赖的关联包,但是卸载时只删除单个包,无法卸载关联的包。pip-autoremove就是为了解决卸载关联包的问题。安装方法通过下面的命令安装:pipinsta...
- 用Python在Word文档中插入和删除文本框
-
在当今自动化办公需求日益增长的背景下,通过编程手段动态管理Word文档中的文本框元素已成为提升工作效率的关键技术路径。文本框作为文档排版中灵活的内容容器,既能承载多模态信息(如文字、图像),又可实现独...
- Python 从列表中删除值的多种实用方法详解
-
#Python从列表中删除值的多种实用方法详解在Python编程中,列表(List)是一种常用的数据结构,具有动态可变的特性。当我们需要从列表中删除元素时,根据不同的场景(如按值删除、按索引删除、...
- Python 中的前缀删除操作全指南(python删除前导0)
-
1.字符串前缀删除1.1使用内置方法Python提供了几种内置方法来处理字符串前缀的删除:#1.使用removeprefix()方法(Python3.9+)text="...
- 每天学点Python知识:如何删除空白
-
在Python中,删除空白可以分为几种不同的情况,常见的是针对字符串或列表中空白字符的处理。一、删除字符串中的空白1.删除字符串两端的空白(空格、\t、\n等)使用.strip()方法:s...
- Linux系统自带Python2&yum的卸载及重装
-
写在前面事情的起因是我昨天在测试Linux安装Python3的shell脚本时,需要卸载Python3重新安装一遍。但是通过如下命令卸载python3时,少写了个3,不小心将系统自带的python2也...
- 如何使用Python将多个excel文件数据快速汇总?
-
在数据分析和处理的过程中,Excel文件是我们经常会遇到的数据格式之一。本文将通过一个具体的示例,展示如何使用Python和Pandas库来读取、合并和处理多个Excel文件的数据,并最终生成一个包含...
- 【第三弹】用Python实现Excel的vlookup功能
-
今天继续用pandas实现Excel的vlookup功能,假设我们的2个表长成这样:我们希望把Sheet2的部门匹在Sheet1的最后一列。话不多说,先上代码:importpandasaspd...
- python中pandas读取excel单列及连续多列数据
-
案例:想获取test.xls中C列、H列以后(当H列后列数未知时)的所有数据。importpandasaspdfile_name=r'D:\test.xls'#表格绝对...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python自定义函数 (53)
- python进度条 (67)
- python吧 (67)
- python字典遍历 (54)
- python的for循环 (65)
- python格式化字符串 (61)
- python串口编程 (60)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python字典增加键值对 (53)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python人脸识别 (54)
- python多态 (60)
- python命令行参数 (53)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)