判斷python對(duì)象是否可調(diào)用的三種方式及其區(qū)別詳解
查找資料,基本上判斷python對(duì)象是否為可調(diào)用的函數(shù),有三種方法
使用內(nèi)置的callable函數(shù)
callable(func)
用于檢查對(duì)象是否可調(diào)用,返回True也可能調(diào)用失敗,但是返回False一定不可調(diào)用。
官方文檔:https://docs.python.org/3/library/functions.html?highlight=callable#callable
判斷對(duì)象類型是否是FunctionType
type(func) is FunctionType # 或者 isinstance(func, FunctionType)
判斷對(duì)象是否實(shí)現(xiàn) __call__ 方法
hasattr(func, '__call__')
寫個(gè)小demo,測(cè)試下這三種驗(yàn)證方式的區(qū)別
from types import FunctionType __author__ = 'blackmatrix' class ClassA: @staticmethod def func_a(): pass @classmethod def func_b(cls, arg): pass def func_c(self, arg): pass def func_d(): pass if __name__ == '__main__': class_a = ClassA() print('靜態(tài)方法,實(shí)例調(diào)用驗(yàn)證') print("callable(class_a.func_a) result: {result}".format(result=callable(class_a.func_a))) print("type(class_a.func_a) is FunctionType result: {result}".format(result=type(class_a.func_a) is FunctionType)) print("hasattr(class_a.func_a, '__call__') result: {result}".format(result=hasattr(class_a.func_a, '__call__'))) print('靜態(tài)方法,類調(diào)用驗(yàn)證') print("callable(ClassA.func_a) result: {result}".format(result=callable(ClassA.func_a))) print("type(ClassA.func_a) is FunctionType result: {result}".format(result=type(ClassA.func_a) is FunctionType)) print("hasattr(ClassA.func_a, '__call__') result: {result}".format(result=hasattr(ClassA.func_a, '__call__'))) print('類方法驗(yàn)證') print("callable(ClassA.func_b) result: {result}".format(result=callable(ClassA.func_b))) print("type(ClassA.func_b) is FunctionType result: {result}".format(result=type(ClassA.func_b) is FunctionType)) print("hasattr(ClassA.func_b, '__call__') result: {result}".format(result=hasattr(ClassA.func_b, '__call__'))) print('實(shí)例方法驗(yàn)證') print("callable(class_a.func_c) result: {result}".format(result=callable(class_a.func_c))) print("type(class_a.func_c) is FunctionType result: {result}".format(result=type(class_a.func_c) is FunctionType)) print("hasattr(class_a.func_c, '__call__') result: {result}".format(result=hasattr(class_a.func_c, '__call__'))) print('函數(shù)驗(yàn)證') print("callable(func_d) result: {result}".format(result=callable(func_d))) print("type(func_d) is FunctionType result: {result}".format(result=type(func_d) is FunctionType)) print("hasattr(func_d, '__call__') result: {result}".format(result=hasattr(func_d, '__call__')))
通過運(yùn)行結(jié)果,發(fā)現(xiàn)三種方法的驗(yàn)證結(jié)果并不相同。
主要是type(func) is FunctionType方法,在驗(yàn)證類方法和實(shí)例方法時(shí),會(huì)返回False,
從調(diào)試的結(jié)果上看,實(shí)例方法,和類方法的類型都是<class 'method'>,不是FunctionType,所以會(huì)返回False
靜態(tài)方法,實(shí)例調(diào)用驗(yàn)證 callable(class_a.func_a) result: True type(class_a.func_a) is FunctionType result: True hasattr(class_a.func_a, '__call__') result: True 靜態(tài)方法,類調(diào)用驗(yàn)證 callable(ClassA.func_a) result: True type(ClassA.func_a) is FunctionType result: True hasattr(ClassA.func_a, '__call__') result: True 類方法驗(yàn)證 callable(ClassA.func_b) result: True type(ClassA.func_b) is FunctionType result: False hasattr(ClassA.func_b, '__call__') result: True 實(shí)例方法驗(yàn)證 callable(class_a.func_c) result: True type(class_a.func_c) is FunctionType result: False hasattr(class_a.func_c, '__call__') result: True 函數(shù)驗(yàn)證 callable(func_d) result: True type(func_d) is FunctionType result: True hasattr(func_d, '__call__') result: True
因?yàn)镻ython中分為函數(shù)(function)和方法(method),函數(shù)是Python中一個(gè)可調(diào)用對(duì)象(用戶定義的可調(diào)用對(duì)象,及l(fā)ambda表達(dá)式創(chuàng)建的函數(shù),都是函數(shù),其類型都是FunctionType),方法是一種特殊的類函數(shù)。
官方文檔中,對(duì)于method的定義:
Methods are always bound to an instance of a user-defined class
類方法和類進(jìn)行綁定,實(shí)例方法與實(shí)例進(jìn)行綁定,所以兩者的類型都是method。
而靜態(tài)方法,本身即不和類綁定,也不和實(shí)例綁定,不符合上述定義,所以其類型應(yīng)該是function。
其中還有需要注意的是,如果一個(gè)類實(shí)現(xiàn)了__call__方法,那么其實(shí)例也會(huì)成為一個(gè)可調(diào)用對(duì)象,其類型為創(chuàng)建這個(gè)實(shí)例的類,而不是函數(shù)或方法。
class TheClass: def __call__(self, *args, **kwargs): return self if __name__ == '__main__': the_class = TheClass() # True print('class_instance callable {callable} '.format(callable=callable(the_class)))
所以通過類型去判斷Python對(duì)象是否可調(diào)用,需要同時(shí)判斷是函數(shù)(FunctionType)還是方法(MethodType),或者類是否實(shí)現(xiàn)__call__方法。
如果只是單純判斷python對(duì)象是否可調(diào)用,用callable()方法會(huì)更穩(wěn)妥。
以上這篇判斷python對(duì)象是否可調(diào)用的三種方式及其區(qū)別詳解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- python 通過字符串調(diào)用對(duì)象屬性或方法的實(shí)例講解
- Python面向?qū)ο蟪绦蛟O(shè)計(jì)多繼承和多態(tài)用法示例
- Python面向?qū)ο蟪绦蛟O(shè)計(jì)之私有屬性及私有方法示例
- Python中獲取對(duì)象信息的方法
- Python檢測(cè)一個(gè)對(duì)象是否為字符串類的方法
- Python中的對(duì)象,方法,類,實(shí)例,函數(shù)用法分析
- Python中動(dòng)態(tài)獲取對(duì)象的屬性和方法的教程
- python進(jìn)階教程之函數(shù)對(duì)象(函數(shù)也是對(duì)象)
- Python對(duì)象的深拷貝和淺拷貝詳解
- Python面向?qū)ο髮?shí)現(xiàn)一個(gè)對(duì)象調(diào)用另一個(gè)對(duì)象操作示例
相關(guān)文章
Opencv中的cv2.calcHist()函數(shù)的作用及返回值說明
這篇文章主要介紹了Opencv中的cv2.calcHist()函數(shù)的作用及返回值說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11Python實(shí)現(xiàn)將元組中的元素作為參數(shù)傳入函數(shù)的操作
這篇文章主要介紹了Python實(shí)現(xiàn)將元組中的元素作為參數(shù)傳入函數(shù)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-06-06使用python telnetlib批量備份交換機(jī)配置的方法
今天小編就為大家分享一篇使用python telnetlib批量備份交換機(jī)配置的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-07-07python實(shí)現(xiàn)提取str字符串/json中多級(jí)目錄下的某個(gè)值
今天小編就為大家分享一篇python實(shí)現(xiàn)提取str字符串/json中多級(jí)目錄下的某個(gè)值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-02-02Django項(xiàng)目的初步創(chuàng)建與簡(jiǎn)單配置
本文主要介紹了Django項(xiàng)目的初步創(chuàng)建與簡(jiǎn)單配置,詳細(xì)介紹了如何安裝和配置Django,包括創(chuàng)建項(xiàng)目、數(shù)據(jù)庫配置、路由等,通過本文可以了解如何使用Django創(chuàng)建自己的Web應(yīng)用程序2023-09-09解決PIP安裝第三方庫報(bào)錯(cuò)SSL: CERTIFICATE_VERIFY_FAILED問題
這篇文章主要介紹了解決PIP安裝第三方庫報(bào)錯(cuò)SSL: CERTIFICATE_VERIFY_FAILED問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01python 高效去重復(fù) 支持GB級(jí)別大文件的示例代碼
今天小編就為大家分享一篇python 高效去重復(fù) 支持GB級(jí)別大文件的示例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-11-11