函數是組織好的,可重複使用的,用來實作單一,或相關聯功能的代碼段。
函數能提高應用的子產品性,和代碼的重複使用率。你已經知道python提供了許多内建函數,比如<code>print()</code>。但你也可以自己建立函數,這被叫做使用者自定義函數。
你可以定義一個由自己想要功能的函數,以下是簡單的規則:
函數代碼塊以def關鍵詞開頭,後接函數辨別符名稱和圓括号()。
任何傳入參數和自變量必須放在圓括号中間。圓括号之間可以用于定義參數。
函數的第一行語句可以選擇性地使用文檔字元串—用于存放函數說明。
函數内容以冒号起始,并且縮進。
<code>return[expression]</code>結束函數,選擇性地傳回一個值給調用方。不帶表達式的return相當于傳回 <code>none</code>。
預設情況下,參數值和參數名稱是按函數聲明中定義的的順序比對起來的。
以下為一個簡單的python函數,它将一個字元串作為傳入參數,再列印到标準顯示裝置上。
定義一個函數隻給了函數一個名稱,指定了函數裡包含的參數,和代碼塊結構。
這個函數的基本結構完成以後,你可以通過另一個函數調用執行,也可以直接從python提示符執行。
如下執行個體調用了<code>printme()</code>函數:
以上執行個體輸出結果:
所有參數(自變量)在python裡都是按引用傳遞。如果你在函數裡修改了參數,那麼在調用這個函數的函數裡,原始的參數也被改變了。
例如:
傳入函數的和在末尾添加新内容的對象用的是同一個引用。故輸出結果如下:
以下是調用函數時可使用的正式參數類型:
必備參數
命名參數
預設參數
不定長參數
必備參數須以正确的順序傳入函數。調用時的數量必須和聲明時的一樣。
調用printme()函數,你必須傳入一個參數,不然會出現文法錯誤:
命名參數和函數調用關系緊密,調用方用參數的命名确定傳入的參數值。你可以跳過不傳的參數或者亂序傳參,因為python解釋器能夠用參數名比對參數值。用命名參數調用printme()函數:
下例能将命名參數順序不重要展示得更清楚:
調用函數時,預設參數的值如果沒有傳入,則被認為是預設值。下例會列印預設的age,如果age沒有被傳入:
你可能需要一個函數能處理比當初聲明時更多的參數。這些參數叫做不定長參數,和上述2種參數不同,聲明時不會命名。基本文法如下:
加了星号(*)的變量名會存放所有未命名的變量參數。選擇不多傳參數也可。如下執行個體:
python 使用 lambda 來建立匿名函數。
lambda隻是一個表達式,函數體比def簡單很多。
lambda的主體是一個表達式,而不是一個代碼塊。僅僅能在lambda表達式中封裝有限的邏輯進去。
lambda函數擁有自己的名字空間,且不能通路自有參數清單之外或全局名字空間裡的參數。
雖然lambda函數看起來隻能寫一行,卻不等同于c或c++的内聯函數,後者的目的是調用小函數時不占用棧記憶體進而增加運作效率。
lambda函數的文法隻包含一個語句,如下:
如下執行個體:
return語句[表達式]退出函數,選擇性地向調用方傳回一個表達式。不帶參數值的return語句傳回none。之前的例子都沒有示範如何傳回數值,下例便告訴你怎麼做:
一個程式的所有的變量并不是在哪個位置都可以通路的。通路權限決定于這個變量是在哪裡指派的。
變量的作用域決定了在哪一部分程式你可以通路哪個特定的變量名稱。兩種最基本的變量作用域如下:
全局變量
局部變量
定義在函數内部的變量擁有一個局部作用域,定義在函數外的擁有全局作用域。
局部變量隻能在其被聲明的函數内部通路,而全局變量可以在整個程式範圍内(包括函數裡面)通路。調用函數時,所有在函數内聲明的變量名稱都将被加入到作用域中。如下執行個體:
但是如果要給全局變量在一個函數裡指派,必須使用global語句。
global varname的表達式會告訴python, varname是一個全局變量,這樣python就不會在局部命名空間裡尋找這個變量了。
例如,我們在全局命名空間裡定義一個變量money。我們再在函數内給變量money指派,然後python會假定money是一個局部變量。然而,我們
并沒有在通路前聲明一個局部變量money,結果就是會出現一個unboundlocalerror的錯誤。取消global語句的注釋就能解決這個問
題。