溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

python Class:面向?qū)ο蟾呒壘幊?__call__& callable()

發(fā)布時(shí)間:2020-04-08 10:15:58 來源:網(wǎng)絡(luò) 閱讀:848 作者:虎皮喵的喵 欄目:編程語言

官網(wǎng)解釋:

3.4.5. Emulating callable objects

  • object.__call__(self[args...])

  • Called when the instance is “called” as a function; if this method is defined, x(arg1, arg2, ...) is a shorthand for x.__call__(arg1,arg2, ...).

看得懂,但看不明白。。。。。真是硬傷。。。。


這兩天發(fā)文老是被審核,想不通,是不是我把廖某的全名打出來有人不爽????


為了更好理解,引用廖某的__call__程序與自己的__repr__ / __str__程序做比較:

#廖:__call__此程序的結(jié)果是輸出輸入的name
class Student1(object):
    def __init__(self, name):
        self.name = name

    def __call__(self):
        print('My name is %s.' % self.name)    

h = Student1('MumU')
print 'liao:', h        
           
#我:__repr__ / __str__ 此程序的結(jié)果也是輸出輸入的name
class Student2(object):
    def __init__(self, name):
        self.name = name

    def __str__(self):
        return 'Student2 name:%s'%self.name
    __repr__ = __str__        
    
l = Student2('U')
print 'me:', l

運(yùn)行結(jié)果:

liao: <__main__.Student1 object at 0x7f5fea3108d0>
me: Student2 name:U

嗯,為啥Student1會輸出這樣呢???

再換一個(gè)試法:程序Class都沒改,只是輸出語句改了(標(biāo)記:####)

#廖:__call__此程序的結(jié)果是輸出輸入的name
class Student1(object):
    def __init__(self, name):
        self.name = name

    def __call__(self):
        print('My name is %s.' % self.name)    

print Student1('MumU')   ####
           
#我:__repr__ / __str__ 此程序的結(jié)果也是輸出輸入的name
class Student2(object):
    def __init__(self, name):
        self.name = name

    def __str__(self):
        return 'Student2 name:%s'%self.name
    __repr__ = __str__        
    
print Student2('U')  ####

運(yùn)行結(jié)果:

liao: <__main__.Student1 object at 0x7f13dc36b8d0>
me: Student2 name:U

嗯,還是一樣,想想也是,因?yàn)檫@輸出寫法和之前的是等價(jià)的。。。。于是我就想,如果__call__是調(diào)用自己的函數(shù)的話,那么要用函數(shù)就得。。。在末尾加()號?!

再試:只改了廖的輸出語句(標(biāo)記:####)

#廖:__call__此程序的結(jié)果是輸出輸入的name
class Student1(object):
    def __init__(self, name):
        self.name = name

    def __call__(self):
        print('My name is %s.' % self.name)    

print Student1('MumU')()   ####
           
#我:__repr__ / __str__ 此程序的結(jié)果也是輸出輸入的name
class Student2(object):
    def __init__(self, name):
        self.name = name

    def __str__(self):
        return 'Student2 name:%s'%self.name
    __repr__ = __str__        
    
print Student2('U')

運(yùn)行結(jié)果:

liao: My name is MumU.
None
me: Student2 name:U

敲你嗎,還真是函數(shù)。。。。

敲了這么多,蒙了也正常,換個(gè)普通的就懂了。

class Animal(object):
    def __init__(self, name):
        self.name = name
    
    def run(self):
        print '%s is running'%self.name
        
dog = Animal('dog')
print '當(dāng)你要查看class的屬性name時(shí):', dog.name
print '當(dāng)你要查看class的方法(函數(shù))時(shí):', dog.run()

運(yùn)行結(jié)果:

當(dāng)你要查看class的屬性name時(shí): dog
當(dāng)你要查看class的方法(函數(shù))時(shí): dog is running
None

查看屬性是不加()號的, 使用方法(函數(shù))時(shí)才需要。

至于為什么運(yùn)行末尾都有個(gè)None??

Because,

dog.run()已經(jīng)執(zhí)行了一次print 了,

    def run(self):
        print '%s is running'%self.name

print '當(dāng)你要查看class的方法(函數(shù))時(shí):', dog.run()

再次執(zhí)行了一次,所以這個(gè)print 就只能輸出None了。


我真是太聰明了,哈哈哈哈哈


callable: 查看對象是否可調(diào)用,即是否為函數(shù)

print 'Student1 可調(diào)用??', callable(Student1('MumU'))       
print 'Student2 可調(diào)用??', callable(Student2('U'))

運(yùn)行結(jié)果:

Student1 可調(diào)用?? True
Student2 可調(diào)用?? False


向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI