主頁 > 資料庫 > 來嘗個鮮,Python3.8幾大新功能體驗,沖鴨!

來嘗個鮮,Python3.8幾大新功能體驗,沖鴨!

2020-09-10 21:00:10 資料庫

640?wx_fmt=png

作者 | 小劉

來源 | 菜鳥學Python

繼3.7版本之后Python再次發布了新版本,雖然新版本帶來了不少調整,但是其中很大一部分都是對代碼底層設計的修改,又或是typing、pickle等不常用的功能,對多數用戶而言影響不大,今天我想重點聊一聊那些將對我們的代碼撰寫產生較大影響的新功能,

在體驗開始前先說下準備作業,由于Python3.8還沒有正式發布,因此通過Anaconda的多版本管理搭建Python3.8新環境的方法是行不通的,我的做法是到官網下載對應的最新版本后單獨安裝,

640?wx_fmt=png


為了避免與現有環境沖突,將其更名為Python38(下圖),下文中的Python如無特殊說明均為Python3.6, Python38為Python3.8接下來就正式開始新特性體驗,

640?wx_fmt=png


1.字典逆序


我們都知道Python中的字典是無序的,Python3.6對這一問題進行了修訂,默認情況下會按照鍵的創建順序進行排序,但也僅限于此,你無法像串列那樣對字典直接進行排序操作,

這一情況在Python3.8中進一步得到改善,Python3.8中reversed()方法增加了對字典物件的支持,可以對字典進行逆序操作

在下面這段代碼中,對字典進行簡單的迭代,將會按照順序輸出字典的鍵,

640?wx_fmt=png

現在改變一下代碼,加入reversed()方法:

640?wx_fmt=png

先來看使用Python3.6的運行結果(下圖),可以看到在Python3.6中,字典是不支持recersed()方法的,


640?wx_fmt=png

然后用Python3.8運行結果如下可以看到,字典按照鍵創建順序的逆序進行了輸出,雖然只是非常小的一點功能提升,但是在某些場景下對于字典物件的應用可能會起到非常關鍵的作用,

640?wx_fmt=png



2.位置引數


在Python3.8中的引數傳遞方面引入了一個新的特性:PEP 570 Positional-Only Argument——限定位置引數,下面就詳細聊聊這究竟是怎么回事,

一般來說,Python中的引數傳遞有三種形式:位置引數、關鍵字引數和可變引數,為了避免不必要的麻煩,規定在可變引數之后只允許使用關鍵字引數,可是即便如此還是給程式員們留下了很大的自由空間,比如在可變引數之前,位置引數和關鍵字引數的使用幾乎不受限制,這樣就出現了一個問題,假如一個團隊中很多人進行合作開發,函式的定義形式和呼叫模式是很難規范和統一的

因此Python3.8就引入了一個“Positional-Only Argument”的概念和分隔符“/”,在分隔符“/”左側的引數,只允許使用位置引數的形式進行傳遞,

舉個例子來進行說明,首先建立下面這樣一個函式,由于函式中使用了分隔符“/”,因此只能使用Python3.8運行,

def add_num(x, y, z=100, /, a=100):     print(x + y + z + a)
print(x + y + z + a)


嘗試以下面這種方式呼叫函式:

add_num(1, 2, z=4, a=5)

結果在運行的時候發生了報錯:

640?wx_fmt=png

接著嘗試全部以位置引數的形式呼叫函式(如下),結果順利執行,可見“Positional-Only Argument”對分隔符“/”右側的引數形式并沒有限制

# 輸入add_num(1, 2, 4, 5)# 輸出12
add_num(1, 2, 4, 5)
# 輸出
12

那么如果只給定前兩個引數,后面兩個引數使用默認值又如何呢?通過下面的呼叫可以發現,也是可以正常運行的,

# 輸入add_num(1, 2)# 輸出203
add_num(1, 2)
# 輸出
203

通過上面這個例子我們發現Python3.8對于引數傳遞的限制僅僅作用于分隔符“/”的左側,而且只是在函式呼叫時發生作用,


3.賦值運算式


Python3.8中新增了賦值運算式“:=”運算子,簡單來說就是把運算操作和賦值操作放在了一起,有點類似于“a+=b”這種表達方式,我想賦值運算式的出現應該是python追求簡潔的傳統理念所致,

來看下面這段代碼,在func函式的if陳述句中,運算、賦值、判斷操作在同一條陳述句中完成,即使變數a原本不存在也沒關系,

# 輸入def func(x, y, z):     if (a := x + y) != z:         print(a)     else:         print(z)func(1, 2, 5)# 輸出3
def func(x, y, z):
if (a := x + y) != z:
print(a)
else:
print(z)
func(1, 2, 5)
# 輸出
3

當然,就上面這段代碼本身來看,將 x+y 的結果進行賦值似乎意義不大,但是如果運算運算式的計算量非常大或者要進行大規模獨寫等操作的話,重復執行對代碼的效率將造成大的影響;而如果事先對運算運算式賦值則需要多寫一行代碼,


目前來看,賦值運算式最重要的作用就是使代碼變得更加簡潔,至于運行效率的差異,目前還沒有驗證,


4.快速除錯


在之前的Python版本中,“f運算式”——f'{expr}'的作用與eval()函式基本相同,例如:

  • f'{[1, 2, 3, 4, 5, 6]}'的結果是串列[1, 2, 3, 4, 5, 6];

  • f'{3 + 2}'的結果是運算后的值5,

Python3.8中對該功能進行了優化,f'{expr}'陳述句中增加了對等號“=”的支持,在保留原來功能的基礎上,還能夠同時輸出運算運算式本身,

例如執行先面這段代碼,除了計算并輸出運算結果外,還會將“=”和其左側的算式一并輸出:

x = 3print(f'{x * 2 = }')
print(f'{x * 2 = }')

執行結果:

640?wx_fmt=png

f'{expr}'不僅適用于基本的算術運算,還能夠進行其他物件的操作,以串列為例,令lst=[1, 2, 3, 4, 5, 6],現在對其進行擴展操作:

lst = eval('[1, 2, 3, 4, 5, 6]')print(f'{lst = }')print(f'{lst + [7] = }')
print(f'{lst = }')
print(f'{lst + [7] = }')

運行結果如下:

640?wx_fmt=png


函式運算同樣適用,例如對兩個串列求交集,執行下面這段代碼:

lst1 = [1, 2, 3, 4, 5]lst2 = [3, 5, 7]print(f'{list(set(lst1).intersection(set(lst2))) = }')
lst2 = [3, 5, 7]
print(f'{list(set(lst1).intersection(set(lst2))) = }')

運行結果:

640?wx_fmt=png

相比僅輸出結果,連帶運算運算式一起輸出有助于定位檢查,在除錯代碼的時候使用真的是快捷又方便


5.共享記憶體


行程是系統進行資源分配的獨立單位,在以前的python版本中,行程間的資料互動只能通過Queue、Pipes等方式來實作,資料無法直接共享,

在Python 3.8中,multiprocessing模塊提供了SharedMemory類,可以在不同的Python行程之間創建共享的記憶體block,目前支持int、float、str、bytes、bool、None、numpy.ndarray等一部分Python物件,

還是舉個例子來進行說明,在下面這段代碼中建立了2個行程,在行程1中對串列中的每個元素執行+10操作,行程1結束后執行行程2,輸出串列內容,

640?wx_fmt=png

由于行程之間資料無法共享,因此行程2中輸出的串列是沒有進行過+10操作的內容:

640?wx_fmt=png

現在我們對代碼進行一下小小的修改,nums不是作為一個普通的list,而是作為一個共享記憶體物件來創建,代碼如下:

640?wx_fmt=png

由于shared_memory是Python3.8中的新增內容,因此在Python3.6下運行會出錯,我們還是用Python3.8來運行這段代碼(結果如下)可以看到,行程2中輸出的結果與行程1中是一樣的,兩個行程之間通過shared_memory實作了資料共享,

640?wx_fmt=png

當然,shared_memory在實際應用中肯定不會如此簡單,

  • 比如SharedMemory.ShareableList和SharedMemory.SharedMemory的使用本身有很多規則和限制、

  • 比如需要考慮資料鎖的問題等等,

  • 但是共享記憶體確實為行程間通訊提供了一個新的解決方案,而且據說其通訊效率也是非常之高的,

Python3.8發布的新特性和新功能還有很多,對一些內置模塊的改進和優化則更多,想嘗鮮的同學可以點擊閱讀原文,了解Python3.8詳情!你對Python3.8新特性怎么看,歡迎吱一聲留言!

—————————————

往期精彩:

  • 人民日報終發文:國航“避重就輕、不作為、護犢子、體驗差、聽不進批評”

  • 華為延期,三星下架,講講折疊屏為什么這么難

  • 遇事不決賴毛子,美國這次打算封殺變臉APP

640?wx_fmt=png

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/3434.html

標籤:其他

上一篇:咱們從頭到尾說一次 Java 垃圾回收

下一篇:MySQL學習筆記十:游標/動態SQL/臨時表/事務

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more