摘要:這里的關鍵詞函數必須明確指明,不能通過位置推斷則代表任意數量的關鍵詞參數添加的新特性,使得可以在函數參數之外使用這里的逗號不能漏掉所謂的解包實際上可以看做是去掉的元組或者是去掉的字典。
項目地址:https://git.io/pytips
函數調用的參數規則與解包Python 的函數在聲明參數時大概有下面 4 種形式:
不帶默認值的:def func(a): pass
帶有默認值的:def func(a, b = 1): pass
任意位置參數:def func(a, b = 1, *c): pass
任意鍵值參數:def func(a, b = 1, *c, **d): pass
在調用函數時,有兩種情況:
沒有關鍵詞的參數:func("G", 20)
帶有關鍵詞的參數:func(a = "G", b = 20)(其中帶有關鍵詞調用可以不考慮順序:func(b = 20, a = "G")
當然,這兩種情況是可以混用的:func("G", b = 20),但最重要的一條規則是位置參數不能在關鍵詞參數之后出現:
def func(a, b = 1): pass func(a = "G", 20) # SyntaxError 語法錯誤
File "", line 3 func(a = "G", 20) # SyntaxError 語法錯誤 ^ SyntaxError: positional argument follows keyword argument
另外一條規則是:位置參數優先權:
def func(a, b = 1): pass func(20, a = "G") # TypeError 對參數 a 重復賦值
--------------------------------------------------------------------------- TypeError Traceback (most recent call last)in () 1 def func(a, b = 1): 2 pass ----> 3 func(20, a = "G") # TypeError 對參數 a 重復賦值 TypeError: func() got multiple values for argument "a"
最保險的方法就是全部采用關鍵詞參數。
任意參數任意參數可以接受任意數量的參數,其中*a的形式代表任意數量的位置參數,**d代表任意數量的關鍵詞參數:
def concat(*lst, sep = "/"): return sep.join((str(i) for i in lst)) print(concat("G", 20, "@", "Hz", sep = ""))
G20@Hz
上面的這個def concat(*lst, sep = "/")的語法是PEP 3102提出的,在 Python 3.0 之后實現。這里的關鍵詞函數必須明確指明,不能通過位置推斷:
print(concat("G", 20, "-")) # Not G-20
G/20/-
**d則代表任意數量的關鍵詞參數
def dconcat(sep = ":", **dic): for k in dic.keys(): print("{}{}{}".format(k, sep, dic[k])) dconcat(hello = "world", python = "rocks", sep = "~")
hello~world python~rocksUnpacking
Python 3.5 添加的新特性(PEP 448),使得*a、**d可以在函數參數之外使用:
print(*range(5)) lst = [0, 1, 2, 3] print(*lst) a = *range(3), # 這里的逗號不能漏掉 print(a) d = {"hello": "world", "python": "rocks"} print({**d}["python"])
0 1 2 3 4 0 1 2 3 (0, 1, 2) rocks
所謂的解包(Unpacking)實際上可以看做是去掉()的元組或者是去掉{}的字典。這一語法也提供了一個更加 Pythonic 地合并字典的方法:
user = {"name": "Trey", "website": "http://treyhunner.com"} defaults = {"name": "Anonymous User", "page_name": "Profile Page"} print({**defaults, **user})
{"page_name": "Profile Page", "name": "Trey", "website": "http://treyhunner.com"}
在函數調用的時候使用這種解包的方法則是 Python 2.7 也可以使用的:
print(concat(*"ILovePython"))
I/L/o/v/e/P/y/t/h/o/n參考
The Idiomatic Way to Merge Dictionaries in Python
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/37818.html
摘要:項目地址相信很多人在格式化字符串的時候都用的語法,提出一種更先進的格式化方法并成為的標準用來替換舊的格式化語法,從開始已經實現了這一方法其它解釋器未考證。 項目地址:https://git.io/pytips 相信很多人在格式化字符串的時候都用%s % v的語法,PEP 3101 提出一種更先進的格式化方法 str.format() 并成為 Python 3 的標準用來替換舊的 %s ...
摘要:項目地址中的函數式編程函數式編程英語或稱函數程序設計,又稱泛函編程,是一種編程范型,它將電腦運算視為數學上的函數計算,并且避免使用程序狀態以及易變對象。 項目地址:https://git.io/pytips Python 中的函數式編程 函數式編程(英語:functional programming)或稱函數程序設計,又稱泛函編程,是一種編程范型,它將電腦運算視為數學上的函數計算,并且...
摘要:項目地址提供兩種內置排序方法,一個是只針對的原地排序方法,另一個是針對所有可迭代對象的非原地排序方法。 項目地址:https://git.io/pytips Python 提供兩種內置排序方法,一個是只針對 List 的原地(in-place)排序方法 list.sort(),另一個是針對所有可迭代對象的非原地排序方法 sorted()。 所謂原地排序是指會立即改變被排序的列表對象,就...
項目地址:https://git.io/pytips Python 的修飾器是一種語法糖(Syntactic Sugar),也就是說: @decorator @wrap def func(): pass 是下面語法的一種簡寫: def func(): pass func = decorator(wrap(func)) 關于修飾器的兩個主要問題: 修飾器用來修飾誰 誰可以作為修飾器...
摘要:模塊的導入一定要放在最上方,也就是在所有其它模塊之前導入。最后一列是每個新特性所對應的及簡單描述。相對導入則可以使用為標記導入相對目錄中的模塊,具體可以參考這篇文章導入模塊的幾種姿勢。 項目地址:https://git.io/pytips 我們經常從一些組織良好的 Python 項目中看到 __future__ 的身影,例如: from __future__ import absolu...
閱讀 1678·2021-09-26 10:00
閱讀 2938·2021-09-06 15:00
閱讀 3542·2021-09-04 16:40
閱讀 2306·2019-08-30 15:44
閱讀 722·2019-08-30 10:59
閱讀 1890·2019-08-29 18:34
閱讀 3623·2019-08-29 15:42
閱讀 2298·2019-08-29 15:36