您好,欢迎访问一九零五行业门户网

终于介绍Python 3.9

今天python教程栏目介绍python 3.9。
python 3.9,来了!
过去一年,来自世界各地的开发者们一直在致力于python3.8的改进。python 3.9 beta版本已经存在了一段时间,第一个正式版本于2020年10月5日发布。
每个python版本都包含新开发和改进的功能,python 3.9也不例外。
【python学习交流群】
下面介绍python 3.9几个主要的新功能。
1. 字典(合并&更新)运算符字典是python中最基础的数据结构之一,并且随着python版本的迭代,性能得到不断地优化。
python3.9中,合并(|)和更新(|=)运算符已添加到dict类中。这些更新完善了现有的dict.update和{** d1,** d2}方法。
传统合并字典的方法:
>>> pycon = {2016: portland, 2018: cleveland} # 字典1>>> europython = {2017: rimini, 2018: edinburgh, 2019: basel} # 字典2# 方法一>>> {**pycon, **europython}{2016: 'portland', 2018: 'edinburgh', 2017: 'rimini', 2019: 'basel'}#方法二>>> merged = pycon.copy>>> for key, value in europython.items:... merged[key] = value...>>> merged{2016: 'portland', 2018: 'edinburgh', 2017: 'rimini', 2019: 'basel'}复制代码
这两种方法都合并了字典而不更改原始数据。请注意,字典1中“cleveland”已被合并的字典2中“edinburgh”覆盖。
你也可以更新字典1:
>>> pycon.update(europython)>>> pycon{2016: 'portland', 2018: 'edinburgh', 2017: 'rimini', 2019: 'basel'}复制代码
新版本的python引入了两个新的字典运算符:合并(|)和更新(|=)。你可以使用|合并两个字典,而|=用于更新字典:
>>> pycon = {2016: portland, 2018: cleveland}>>> europython = {2017: rimini, 2018: edinburgh, 2019: basel}>>> pycon | europython # 合并{2016: 'portland', 2018: 'edinburgh', 2017: 'rimini', 2019: 'basel'}>>> pycon |= europython # 更新>>> pycon{2016: 'portland', 2018: 'edinburgh', 2017: 'rimini', 2019: 'basel'}复制代码
d1|d2和{** d1,** d2}的作用类似,都用于合并字典取并集,遇到相同key,后者会将前者覆盖。
使用|的优势之一是它适用于类似字典的类型,并在合并后保持原来的类型:
>>> from collections import defaultdict>>> europe = defaultdict(lambda: , {norway: oslo, spain: madrid})>>> africa = defaultdict(lambda: , {egypt: cairo, zimbabwe: harare})>>> europe | africadefaultdict(<function <lambda> at 0x7f0cb42a6700>,{'norway': 'oslo', 'spain': 'madrid', 'egypt': 'cairo', 'zimbabwe': 'harare'})>>> {**europe, **africa}{'norway': 'oslo', 'spain': 'madrid', 'egypt': 'cairo', 'zimbabwe': 'harare'}复制代码
|=的作用是更新字典,类似于.update:
>>> libraries = {... collections: container datatypes,... math: mathematical functions,... }>>> libraries |= {zoneinfo: iana time zone support}>>> libraries{'collections': 'container datatypes', 'math': 'mathematical functions','zoneinfo': 'iana time zone support'}复制代码
|=还可以将类似字典的数据结构用于更新:
>>> libraries |= [(graphlib, functionality for graph-like structures)]>>> libraries{'collections': 'container datatypes', 'math': 'mathematical functions','zoneinfo': 'iana time zone support','graphlib': 'functionality for graph-like structures'}复制代码
2. 删除字符串前缀和后缀在python 3.9中,可以使用.removeprefix和.removesuffix分别删除字符串的开头或结尾:
>>> three cool features in python.removesuffix( python)'three cool features in'>>> three cool features in python.removeprefix(three )'cool features in python'>>> three cool features in python.removeprefix(something else)'three cool features in python'复制代码
有人会说.strip方法也可以呀,但是该方法会出现误删操作:
>>> three cool features in python.strip( python)'ree cool features i'复制代码
可以看到,明明想删掉结尾的单词python,但是开头的there也被删除了一部分-th。
所以.removeprefix和.removesuffix可能更精准一些。
3. zoneinfo时区模块zoneinfo是python3.9新引入的模块,zoneinfo可以访问internet号码分配机构(iana)时区数据库。iana每年都会多次更新其数据库,这是时区信息的最权威来源。
使用zoneinfo,可以获得数据库中描述任何时区的对象:
>>> from zoneinfo import zoneinfo>>> zoneinfo(america/vancouver)zoneinfo.zoneinfo(key='america/vancouver')>>> from zoneinfo import zoneinfo>>> from datetime import datetime, timedelta>>> # 夏令时>>> dt = datetime(2020, 10, 31, 12, tzinfo=zoneinfo(america/los_angeles))>>> print(dt)2020-10-31 12:00:00-07:00>>> dt.tzname'pdt'>>> # 标准时间>>> dt += timedelta(days=7)>>> print(dt)2020-11-07 12:00:00-08:00>>> print(dt.tzname)pst复制代码
4. 内置集合类型用于类型提示在类型提示中,现在可以将内置集合类型(例如list和dict)用作泛型类型,而不必从typing中导入相应的大写类型(例如list或dict)。
def greet_all(names: list[str]) -> none:for name in names:print(hello, name)复制代码
5. 拓扑排序python 3.9添加了一个新的模块graphlib,其中包含graphlib.topologicalsorter类,以提供执行拓扑排序的功能。
>>> dependencies = {... realpython-reader: {feedparser, html2text},... feedparser: {sgmllib3k},... }...>>> from graphlib import topologicalsorter>>> ts = topologicalsorter(dependencies)>>> list(ts.static_order)['html2text', 'sgmllib3k', 'feedparser', 'realpython-reader']复制代码
6. 最小公倍数(lcm)python长期以来一直具有用于计算两个数字的最大公约数(gcd)的功能:
>>> import math>>> math.gcd(49, 14)7复制代码
最小公倍数(lcm)与最大公约数(gcd)有关,可以根据gcd定义lcm:
>>> def lcm(num1, num2):... if num1 == num2 == 0:... return 0... return num1 * num2 // math.gcd(num1, num2)...>>> lcm(49, 14)98复制代码
在python 3.9中,不再需要定义自己的lcm函数,它新增了计算最小公倍数功能:
>>> import math>>> math.lcm(49, 14)98复制代码
7. 更强大的python解析器python 3.9最酷的功能之一是大家在日常编程中不会注意到的功能,那就是解析器的更新。解析器是python解释器的基本组件。在最新版本中,解析器已重新构建。
python之前一直使用ll(1)解析器将源代码解析为解析树。你可以将ll(1)解析器视为一次读取一个字符,并解释源代码而无需回溯的解析器。
新解释器是基于peg(parsing expression grammar)实现的,并非ll(1)。新解析器的性能可以与旧解析器媲美,在设计新语言功能时,peg比ll(1)更灵活。
在整个标准库中,peg解析器稍快一些,然而也使用了更多的内存。实际上,使用新解析器时,很难能感知到性能的好坏。
相关免费学习推荐:python教程(视频)
以上就是终于介绍python 3.9的详细内容。
其它类似信息

推荐信息