Python技巧之變長和定長序列拆分
Python中的任何序列(可迭代的對象)都可以通過賦值操作進行拆分,包括但不限于元組、列表、字符串、文件、迭代器、生成器等。
1.元組拆分
元組拆分是最為常見的一種拆分,示例如下:
p = (4, 5) x, y = p print(x, y) # 4 5
如果寫成
x, y, z = p
那么就會拋出ValueError異常: “not enough values to unpack (expected 3, got 2)”
如果寫成
p = (4, 5, 6) x, y = p
那么就會拋出ValueError異常: “ too many values to unpack (expected 2)”
2.字符串拆分
字符串的拆分示意如下:
s = 'Hello' a, b, c, d, e = s print(a) # H
3.拆分時丟棄值
如果在拆分時想丟棄某些特定的值,可以用一個用不到的變量名來作為丟棄值的名稱(常選'_'做為變量名),如下所示:
s = 'Hello' a, b, _, d, _ = s print(a) # H
4.嵌套序列拆分
Python也提供簡潔的對嵌套序列進行拆分的語法。如下所示我們對一個比較復雜的異質(zhì)列表進行拆分:
data = ['zhy', 50, 123.0, (2000, 12, 21)] name, shares, price, (year, month, day) = data print(year) # 2000
如果你想完整地得到(2000, 12, 21)這個表示時間戳的元組,那么你就得這樣寫:
data = ['zhy', 50, 123.0, (2000, 12, 21)] name, shares, price, date = data print(date) # (2000, 12, 21)
5.從任意長度的可迭代對象中拆分
之前我們說過,如果我們想從可迭代對象中分解出N個元素,但如果這個可迭代對象長度超過N,則會拋出異常"too many values to unpack"。針對這個問題的解決方案是采用"*"表達式。
比如我們給定學生的分數(shù),想去掉一個最高分和一個最低分,然后對剩下的學生求平均分,我們可以這樣寫:
def avg(data: list):
return sum(data)/len(data)
# 去掉最高分,最低分然后做均分統(tǒng)計
def drop_first_last(grades):
first, *middle, last = grades
return avg(middle)
print(drop_first_last([1,2,3,4])) # 2.5
還有一種情況是有一些用戶記錄,記錄由姓名+電子郵件+任意數(shù)量的電話號碼組成,則我們可以這樣分解用戶記錄:
record = ['zhy', 'zhy1056692290@qq.com', '773-556234', '774-223333'] name, email, *phone_numbers = record print(phone_numbers) # ['773-556234', '774-223333']
事實上,如果電話號碼為空也是合法的,此時phone_numbers為空列表。
record = ['zhy', 'zhy1056692290@qq.com'] name, email, *phone_numbers = record print(phone_numbers) # []
還有一種使用情況則更為巧妙。如果我們需要遍歷變長元組組成的列表,這些元組長度不一。那么此時*表達式可大大簡化我們的代碼。
records = [('foo', 1, 2), ('bar', 'hello'), ('foo', 3, 4)]
for tag, *args in records:
if tag == 'bar':
print(args)
# ['hello']
在對一些復雜的字符串進行拆分時,*表達式也顯得特別有用。
line = "nobody:*:-2:-2:-2:Unprivileged User:/var/empty:/usr/bin/false"
uname, *fields, home_dir, sh = line.split(':')
print(home_dir) # /var/empty
*表達式也可以和我們前面說的嵌套拆分和變量丟棄一起結(jié)合使用。
record = ['ACME', 50, 123.45, (128, 18, 2012)] name, *_, (*_, year) = record print(year) # 2012
最后再介紹*表達式用于遞歸函數(shù)的一種黑魔法,比如與遞歸求和結(jié)合可以這樣寫:
items = [1, 10, 7, 4, 5, 9]
def sum(items):
head, *tail = items
return head + sum(tail) if tail else head
print(sum(items)) # 36
不過,Python由于自身遞歸棧的限制,并不擅長遞歸。我們最后一個遞歸的例子可以做為一種學術(shù)上的嘗試,但不建議在實踐中使用它。
到此這篇關(guān)于Python技巧之變長和定長序列拆分的文章就介紹到這了,更多相關(guān)Python變長和定長序列拆分內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于Python參數(shù)解析器argparse的應(yīng)用場景
這篇文章主要介紹了關(guān)于Python參數(shù)解析器argparse的應(yīng)用場景,argparse 模塊使編寫用戶友好的命令行界面變得容易,程序定義了所需的參數(shù),而 argparse 將找出如何從 sys.argv 中解析這些參數(shù),需要的朋友可以參考下2023-08-08
Python數(shù)據(jù)結(jié)構(gòu)與算法中的隊列詳解(1)
這篇文章主要為大家詳細介紹了Python的隊列,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03
Python實現(xiàn)Excel文件的合并(以新冠疫情數(shù)據(jù)為例)
這篇將以新冠疫情數(shù)據(jù)為例,詳細介紹了如何利用Python實現(xiàn)合并Excel文件,文中的示例代碼講解詳細,感興趣的可以了解一下2022-03-03
利用Python代碼實現(xiàn)模擬動態(tài)指針時鐘
這篇文章主要為大家詳細介紹了如何利用python和C++代碼實現(xiàn)模擬動態(tài)指針時鐘,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起了解一下2023-04-04
python模塊詳解之pywin32使用文檔(python操作windowsAPI)
pywin32是一個第三方模塊庫,主要的作用是方便python開發(fā)者快速調(diào)用windows API的一個模塊庫,這篇文章主要給大家介紹了關(guān)于python模塊詳解之pywin32使用文檔的相關(guān)資料,文中將python操作windowsAPI介紹的非常詳細,需要的朋友可以參考下2024-01-01

