在這個用例中,我們要討論的是關於函數的傳參問題
我所使用的python版本為3.3.2
對於函數:
5678 def fun(arg): print(arg)🎠
fun('hello,Hongten')
if __name__ == '__main__':
main()
當我們傳遞一個參數給fun()函數,即可印出傳遞的參數值資訊。
這裡印製的資訊是:
hello,Hongten
對於下面的用例:
1
2
36
1
2
36
9
def fun(a=1, b=None, c=None, *args):
print('{0},{1},{2},{3}'.m print('{0},{1},{2},{3}'.format(a, b,format(a, b,format, c, args))
def main():
fun(a='one')
name__ == '__main__': main()當傳遞的參數為:fun(a='one')和fun('one')這樣的傳參都是把值複製給參數a,所有兩種傳參的效果是一樣的: one,None,None,()one,None,None,()當然我們也可以給參數:b,c,*args賦值如: 1 345678 def fun(a=1, b=N,,cmq. },{2},{3}'.format(a, b, c, args)) def main(): fun('one',1,2)(hong
fun('one',1,2)'hong
if __name__ == '__main__': main(), 是給了值
one,1,2, ('hongten',)在上面的列子中,我們不能繞過參數*args前面的參數a,b,c給*args複製:如:def fun(a=1, b=None, c=None, *args): print('{0},{1},{2},{3}'.format(a, b, c, args)) def main(): fun(args=('hongten')) if __name__ == '__main__': main()
Traceback (most recent call last):
File "E:/Python33/python_workspace/test_fun.py", line 21, in
main()幣line 18, in main
fun(args=('hongten'))
TypeError: fun() got an unexpected keyword argument 'args'
但是對於參數:a,b,cword argument 'args'
但是對於參數:a,b,c,c的方式進行賦值
如:
def fun(a=1, b=None, c=None, *args): print('{0},{1},{2},{3}'.format(a, b, c, args)) def main(): fun(c=('hongten'), b=2, a=[1,2,3]) if __name__ == '__main__': main()
運作效果:
[1, 2, 3],2,hongten,()
[1, 2, 3],2,hongten,()
[1, 2, 3],2,hongten,()