上一期我們學習參數傳遞怎么傳遞,也了解了參數的幾種類型。
創(chuàng)新互聯(lián)公司2013年成立,是專業(yè)互聯(lián)網技術服務公司,擁有項目網站制作、成都網站制作網站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元永順做網站,已為上家服務,為永順各地企業(yè)和個人服務,聯(lián)系電話:028-86922220
首先,我們再來回顧一下,形參和實參:
形參是在定義函數時定義的,放在函數名后面的圓括號里,可為空
實參是調用函數時為形參傳入具體的參數值
簡單總結一下,誰調用函數,誰就負責傳入參數。
好吶,本期我們來詳細學習函數幾種參數類型,大綱如下:
python函數的參數名是無意義的,Python允許在調用函數時通過通過名字來傳入參數值。
位置參數:按照形參位置傳入的參數
調用函數時,實參默認按位置順序傳遞的。同時實參個數也要和形參匹配
舉一個小栗子
如果實參的個數與形參不匹配時,調用函數運行就會報錯
Python中,形參與調用函數緊密聯(lián)系在一起的。
關鍵字參數:調用函數時,使形參名稱來傳遞參數,形式為“形參名=實參”
關鍵字參數,又叫命名參數,傳遞時無需考慮參數位置和順序
舉一個小栗子
默認參數:定義函數時,我們可以為形參提前設置具體的值。
在定義函數時,默認參數要放到位置等其他參數后面
在調用函數時,默認參數是可選的。如果傳入新值,則會覆蓋默認值
舉一個小栗子
注意,默認值不能位于位置參數前面,否則程序會報錯誤
不定長參數又名可變參數。
不定長參數指的是可變數量的參數,分兩種情況:
如果不定長參數后面,可以新增參數嗎?
我們通過例子來看,會發(fā)生什么?
運行上面的程序,Python解釋器會報錯
原因是,形參a已經是不定長參數,我們調用的test(2,3,4)傳入的三個實參,系統(tǒng)自動把它們屬于形參a的值,形參b 和形參c就等于沒有值傳入,這時候系統(tǒng)就認為,調用函數的對象,參數沒有傳夠。
為了解決這一報錯,python引入了 強制命名參數
規(guī)定,調用不定參數后面有跟位置參數的函數時,傳入給位置參數時,必須要強制命名參進行傳參。
逆向參數收集針對的對象傳入函數的實參
調用函數時,如果實參是元組,列表或者字典,通過在實參前面加入星號,可以自動把元素進行隔開,然后再轉入給函數進行處理
舉一個小栗子
本期,我們詳細學習了參數幾種類型,為后面我們學習函數,打好基礎。
實踐是檢驗真理的過程,大家多動手練習練習,會有不一樣的奇妙旅程~
好吶,以上是本期內容,歡迎大佬們評論區(qū)指正~
pyhon中的execfile函數可以調用文件來執(zhí)行,當如果執(zhí)行文件需要參數時就將參數放在sys.argv中即可,測試情況如下:
#execfile.py
import sys
if __name__ == '__main__':
print sys.argv
print 'execfile'
sys.argv = 'appcfg.py update sdblog'.split();
print sys.argv
execfile('main.py')
#main.py
import sys
def main():
print 'main'
print sys.argv
if __name__ == '__main__':
main()
執(zhí)行execfile.py test結果如下:
D:\GAE\devexecfile.py test
['D:\\GAE\\dev\\execfile.py', 'test']
execfile
['appcfg.py', 'update', 'sdblog']
main
['appcfg.py', 'update', 'sdblog']
函數參數傳遞機制問題在本質上是調用函數(過程)和被調用函數(過程)在調用發(fā)生時進行通信的方法問題?;镜膮祩鬟f機制有兩
種:值傳遞和引用傳遞。
推薦:Python教程
值傳遞(passl-by-value)過程中,被調函數的形式參數作為被調函數的局部變量處理,即在堆棧中開辟了內存空間以存放由主調函數放
進來的實參的值,從而成為了實參的一個副本。值傳遞的特點是被調函數對形式參數的任何操作都是作為局部變量進行,不會影響主調函
數的實參變量的值。
引用傳遞(pass-by-reference)過程中,被調函數的形式參數雖然也作為局部變量在堆棧中開辟了內存空間,但是這時存放的是由主調函
數放進來的實參變量的地址。被調函數對形參的任何操作都被處理成間接尋址,即通過堆棧中存放的地址訪問主調函數中的實參變量。正
因為如此,被調函數對形參做的任何操作都影響了主調函數中的實參變量。
更多技術請關注Python視頻教程。
#Python 2.5
#這個可以用修飾器來完成
#但是一般不會限制參數類型
#給你個思路:
def argfilter(*types):
def deco(func):
#這是修飾器
def newfunc(*args):
#新的函數
if len(types)==len(args):
correct = True
for i in range(len(args)):
if not isinstance(args[i], types[i]):
#判斷類型
correct = False
if correct:
return func(*args)
#返回原函數值
else:
raise TypeError
else:
raise TypeError
return newfunc
#由修飾器返回新的函數
return deco
#返回作為修飾器的函數
@argfilter(int, str)
#指定參數類型
def func(i, s):
#定義被修飾的函數
print i, s
#之后你想限制類型的話, 就這樣:
#@argfilter(第一個參數的類名, 第二個參數的類名, ..., 第N個參數的類名)
#def yourfunc(第一個參數, 第一個參數, ..., 第N個參數):
#
...
#
#相當于:
#def yourfunc(第一個參數, 第一個參數, ..., 第N個參數):
#
...
#yourfunc = argfilter(第一個參數的類名, 第二個參數的類名, ..., 第N個參數的類名)(yourfunc)
分享題目:python函數入參格式的簡單介紹
文章分享:http://jinyejixie.com/article20/dopchjo.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供云服務器、企業(yè)網站制作、標簽優(yōu)化、電子商務、外貿建站、搜索引擎優(yōu)化
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)