python Class:面向对象高级编程 __call__& callable()
admin
2023-07-23 21:02:13
0

官网解释:

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, ...).

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


这两天发文老是被审核,想不通,是不是我把廖某的全名打出来有人不爽????


为了更好理解,引用廖某的__call__程序与自己的__repr__ / __str__程序做比较:

#廖:__call__此程序的结果是输出输入的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__ 此程序的结果也是输出输入的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

运行结果:

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

嗯,为啥Student1会输出这样呢???

再换一个试法:程序Class都没改,只是输出语句改了(标记:####)

#廖:__call__此程序的结果是输出输入的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__ 此程序的结果也是输出输入的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')  ####

运行结果:

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

嗯,还是一样,想想也是,因为这输出写法和之前的是等价的。。。。于是我就想,如果__call__是调用自己的函数的话,那么要用函数就得。。。在末尾加()号?!

再试:只改了廖的输出语句(标记:####)

#廖:__call__此程序的结果是输出输入的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__ 此程序的结果也是输出输入的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')

运行结果:

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

敲你吗,还真是函数。。。。

敲了这么多,蒙了也正常,换个普通的就懂了。

class Animal(object):
    def __init__(self, name):
        self.name = name
    
    def run(self):
        print '%s is running'%self.name
        
dog = Animal('dog')
print '当你要查看class的属性name时:', dog.name
print '当你要查看class的方法(函数)时:', dog.run()

运行结果:

当你要查看class的属性name时: dog
当你要查看class的方法(函数)时: dog is running
None

查看属性是不加()号的, 使用方法(函数)时才需要。

至于为什么运行末尾都有个None??

Because,

dog.run()已经执行了一次print 了,

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

print '当你要查看class的方法(函数)时:', dog.run()

再次执行了一次,所以这个print 就只能输出None了。


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


callable: 查看对象是否可调用,即是否为函数

print 'Student1 可调用??', callable(Student1('MumU'))       
print 'Student2 可调用??', callable(Student2('U'))

运行结果:

Student1 可调用?? True
Student2 可调用?? False


相关内容

热门资讯

鲁比奥:伊朗收费若成先例,将像... 据美国哥伦比亚广播公司(CBS)援引法新社报道,美国国务卿鲁比奥周四警告称,如果允许伊朗对通过霍尔木...
恐慌之下,有妈妈把纸尿裤塞进了... 6月22日下午两点,济南蝉声轰鸣。山东省第一医科大学附属省立医院门诊大厅里,人流如常。“我不回答。”...
凤凰连线在委华人:委内瑞拉首都... 在委内瑞拉连续强震之后,当地有大量房屋倒塌或受损,而首都加拉加斯的民众也都从建筑物中撤离,在户外避险...
1198.79亿元!宇通客车连... 6月24日,世界品牌实验室发布2026年《中国500最具价值品牌》榜单,宇通客车以1198.79亿元...
活力中国调研行|数据多跑路,居... 【大河财立方 记者 夏晨翔 洪昊旸 雄安新区报道】 儿童活动区里,家长正带着孩子嬉戏玩耍;图书馆里,...
公安部公布4起非法占用农用地典... 6月25日,公安部公布4起非法占用农用地典型案例,旨在依法严厉打击非法占用农用地犯罪,全力守护国家粮...
中关村发展集团原党委书记、董事... 2026年6月25日,北京市第一中级人民法院依法公开宣判中关村发展集团股份有限公司原党委书记、董事长...
大学生因电瓶燃爆,全身90%面... 6月25日,武汉大学生杜均浩被室友电瓶烧伤案刑事与民事部分已一审宣判。
商务部:中方不得不反制美方错误... 据凤凰卫视报道,针对中方将10家美实体纳入出口管制,并在政府采购中限制46家美企,中国商务部新闻发言...
美国画饼,欧盟走过场,立陶宛挑... 曾经冲在“反华”最前线的立陶宛,如今态度似乎发生变化。立陶宛外交部22日证实,叫停了与台湾当局的合作...