终于介绍特币,Python3.9
今天python教程栏目介绍Python 3.9。
Python 3.9,来了!
在过去的一年里,世界各地的开发者都在致力于改进Python3.8,Python 3.9的测试版已经有一段时间了,第一个正式版于2020年10月5日发布。
每个Python版本都包含新的和改进的特性,Python 3.9也不例外。
【python学习交流群】
以下是Python 3.9的一些主要新特性。
00-1010字典是python中最基本的数据结构之一,随着Python版本的迭代,性能不断优化。
在Python3.9中,合并()和更新(=)操作符被添加到了dict类中。这些更新改进了现有的dict.update和{** d1,** d2}方法。
合并字典的传统方法:
Py Con={2016: 波特兰,20183360 克利夫兰 } # Dictionary 1 euro python={ 2017 33 60 里米尼,20183360 爱丁堡,2019: 巴塞尔 } # Dictionary 2#方法1 {* * pycon,* * Europython} {20163360 波特兰,20183360 爱丁堡,2017: 里米尼,2017.合并的[键]=值.合并{20163360 波特兰,2018: 爱丁堡,20173360 里米尼,20193360 巴塞尔 }复制代码。这两种方法都是在不改变原始数据的情况下合并字典。请注意,字典1中的“克利夫兰”已被合并字典2中的“爱丁堡”覆盖。
您也可以更新字典1:
派康。Update(euro Python)PyCon { 2016 33 360 Portland ,20183360 Edinburgh ,20173360 Rimini ,20193360 Basel}复制代码的新版本Python引入了两个新的字典操作符:merge ()和update。您可以使用来合并两个词典,使用=来更新词典:
pycon={2016: 波特兰,2018: 克利夫兰 } europython={2017: 里米尼,2018: 爱丁堡,20193360 巴塞尔 } pycon Europython #合并{20163360 波特兰,20183360 爱丁堡,20173360 里米尼,20193360 巴塞尔 } pycon
使用的一个优点是,它适用于类似字典的类型,并在合并后保持原始类型:
来自collec
tions 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的详细内容,更多请关注盛行IT软件开发工作室其它相关文章!
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。