熱線電話:13121318867

登錄
首頁精彩閱讀python中將函數賦值給變量時需要注意的一些問題
python中將函數賦值給變量時需要注意的一些問題
2018-08-26
收藏

python中將函數賦值給變量時需要注意的一些問題

變量賦值是我們在日常開發中經常會遇到的一個問題,本文主要給大家介紹的是關于python將函數賦值給變量時需要注意的一些問題,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹:

見過兩種函數賦值給變量的形式,一種是

a=f

另一種是    
a=f()

這兩種形式是有區別的,分別總結一下。

1.a=f型屬于將變量指向函數。

用代碼驗證一下:    
>>> f = abs
>>> f(-10)
10

說明變量f現在已經指向了abs函數本身。直接調用abs()函數和調用變量f()完全相同。這是廖雪峰老師python教程上的例子,現在調用f()和調用abs()是一樣的了。

再舉一個工廠函數的例子:    
def maker(N):
 
  def action(X):
 
    return X**N
 
  return action

這個嵌套函數的外層返回值為內層函數的函數名,注意沒有括號,這里有無括號是有很大區別的。此時調用外部函數:    
f=maker(2)

那么如上所述,f便指向了action函數,且限制條件為N=2,可以理解為f為N等于2時的action函數。我們來調用它:    
>>> f(3)
9

證明f和action函數是一樣的。

2.a=f()型屬于將f()的返回值賦值給a的過程

這里的a僅僅接收f()的返回值,如果f()沒有返回值,那么a即被賦值為None。這里值得注意的一點是,在a=f()的執行過程中,f()會運行一次,這也是我剛剛搞明白的,如:    
>>> def add(x,y):
    z=x+y
    print(z)
>>>a=add(3,4)
7

這里雖然只有一個賦值語句執行了,但是卻輸出了結果7,說明賦值過程函數add執行了,然而a的值為None,且只能通過print語句才可以顯示。不只是賦值過程函數會執行,寫在return語句中也會如此。    
>>>def log(func):
   def wrapper(*args, **kw):
     print('call %s():' % func.__name__)
     return func(*args, **kw)
   return wrapper
>>>@log
>>>def now():
    print('2015-3-25')

這是廖雪峰老師python教程裝飾器一節的例程,剛開始我以為return func(*args,**kw)這個語句是返回了now()函數(即func函數)的返回值,后來發現now函數沒有返回值,即為None,所以其實是這個語句在賦值過程,

 func(*args,**kw)執行了,即函數now的print語句執行了。

下面的習題中,一個變形是要求在函數調用的前后打印出'begin call'和'end call',下面一位網友的程序是這么寫的:    
def wrapper(*args,**kw):
   print(t+'begin call')
   result=func(*args,**kw)
   print(t+'end call')
   return result

開始不太理解為什么使用result=func(*args,**kw)這句,后來理解后才明白其實賦值本身并沒有意義,只是這句話同時使得func函數運行了,所以寫成    
def wrapper(*args,**kw):
   print(t+'begin call')
   func(*args,**kw)
   print(t+'end call')
結果也是一樣的。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助


數據分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數據分析師資訊
更多

OK
客服在線
立即咨詢
日韩人妻系列无码专区视频,先锋高清无码,无码免费视欧非,国精产品一区一区三区无码
客服在線
立即咨詢