目錄
今天python教學欄位介紹Python 3.9。 " >今天python教學欄位介紹Python 3.9。
1. 字典(合併&更新)運算子
2. 刪除字串前綴和後綴
3. zoneinfo時區模組
4. 內建集合類型用於類型提示
5. 拓樸排序
6. 最小公倍數(LCM)
7. 更強大的Python解析器
首頁 後端開發 Python教學 終於介紹Python 3.9

終於介紹Python 3.9

Nov 19, 2020 pm 05:21 PM

今天python教學欄位介紹Python 3.9。

終於介紹Python 3.9

Python 3.9,來了!

過去一年,來自世界各地的開發者一直在致力於Python3.8的改進。 Python 3.9 beta版本已經存在了一段時間,第一個正式版本於2020年10月5日發布。

每個Python版本都包含新開發和改進的功能,Python 3.9也不例外。

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的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
威爾R.E.P.O.有交叉遊戲嗎?
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何解決Linux終端中查看Python版本時遇到的權限問題? 如何解決Linux終端中查看Python版本時遇到的權限問題? Apr 01, 2025 pm 05:09 PM

Linux終端中查看Python版本時遇到權限問題的解決方法當你在Linux終端中嘗試查看Python的版本時,輸入python...

在Python中如何高效地將一個DataFrame的整列複製到另一個結構不同的DataFrame中? 在Python中如何高效地將一個DataFrame的整列複製到另一個結構不同的DataFrame中? Apr 01, 2025 pm 11:15 PM

在使用Python的pandas庫時,如何在兩個結構不同的DataFrame之間進行整列複製是一個常見的問題。假設我們有兩個Dat...

如何在10小時內通過項目和問題驅動的方式教計算機小白編程基礎? 如何在10小時內通過項目和問題驅動的方式教計算機小白編程基礎? Apr 02, 2025 am 07:18 AM

如何在10小時內教計算機小白編程基礎?如果你只有10個小時來教計算機小白一些編程知識,你會選擇教些什麼�...

如何在使用 Fiddler Everywhere 進行中間人讀取時避免被瀏覽器檢測到? 如何在使用 Fiddler Everywhere 進行中間人讀取時避免被瀏覽器檢測到? Apr 02, 2025 am 07:15 AM

使用FiddlerEverywhere進行中間人讀取時如何避免被檢測到當你使用FiddlerEverywhere...

什麼是正則表達式? 什麼是正則表達式? Mar 20, 2025 pm 06:25 PM

正則表達式是在編程中進行模式匹配和文本操作的強大工具,從而提高了各種應用程序的文本處理效率。

哪些流行的Python庫及其用途? 哪些流行的Python庫及其用途? Mar 21, 2025 pm 06:46 PM

本文討論了諸如Numpy,Pandas,Matplotlib,Scikit-Learn,Tensorflow,Tensorflow,Django,Blask和請求等流行的Python庫,並詳細介紹了它們在科學計算,數據分析,可視化,機器學習,網絡開發和H中的用途

Uvicorn是如何在沒有serve_forever()的情況下持續監聽HTTP請求的? Uvicorn是如何在沒有serve_forever()的情況下持續監聽HTTP請求的? Apr 01, 2025 pm 10:51 PM

Uvicorn是如何持續監聽HTTP請求的? Uvicorn是一個基於ASGI的輕量級Web服務器,其核心功能之一便是監聽HTTP請求並進�...

Python中如何通過字符串動態創建對象並調用其方法? Python中如何通過字符串動態創建對象並調用其方法? Apr 01, 2025 pm 11:18 PM

在Python中,如何通過字符串動態創建對象並調用其方法?這是一個常見的編程需求,尤其在需要根據配置或運行...

See all articles