分享

全面理解Python中的self

 网摘文苑 2023-03-02 发布于新疆

对于初学Python的同学来说,在class中经常看到self。那么,到底self是个啥?

这得从面向对象说起。Python从设计之初就已经是一门面向对象的语言,在Python中创建一个类和对象是很容易的。

比如,下面的代码片段:定义了一个Employee

#!/usr/bin/python# -*- coding: UTF-8 -*-class Employee: '所有员工的基类' empCount = 0 def __init__(self, name, salary): self.name = name self.salary = salary Employee.empCount += 1 def displayCount(self): print('Total Employee %d' % Employee.empCount) def displayEmployee(self): print('Name : ', self.name, ', Salary: ', self.salary)

类,其实就是定义现实世界中的事物,人、物、等等,任何名词类的东西。比如上面定义的员工

定义只是定义,我们定义了员工具有姓名、薪资这样的属性,但是具体到某个员工,其这些属性值一般都不一样。如何描述某个具体的员工?

有了定义,我们就可以创建实例了,这样就可以描述某个具体的员工了。其他编程语言中一般用关键字new来创建类的实例,但是在 Python 中并没有这个关键字,类的实例化类似于函数调用方式。

下面的代码:实例化Employee类

'创建 Employee 类的第一个对象'emp1 = Employee('张三', 2000)'创建 Employee 类的第二个对象'emp2 = Employee('王五', 5000)

注意:__init__()方法是一种特殊的方法,被称为类的构造函数或初始化方法,当创建这个类的实例的时候,就会调用该方法

而self是什么?self其实是一个占位符,代表类的实例。当我们用上面的代码创建emp1实例的时候,它代表的是emp1这个实例;当创建emp2的时候,代表的是emp2这个实例。

因此,当我们调用下面的实例方法的时候,会分别输出实例的对应属性的值:

emp1.displayEmployee()emp2.displayEmployee()
Name :  张三 , Salary:  2000Name :  王五 , Salary:  5000

self是与类的实例相关的。当然,类本身的一些属性和方法,是不需要实例化也存在的,千万不要搞混淆了。

比如,前面代码中的自定义的类属性empCount。以及,下面的介绍的内置属性。

Python类的内置属性

  • __dict__ : 类的属性的集合:包括自定义的属性
  • __doc__ :类的文档字符串
  • __name__: 类名
  • __module__: 类定义所在的模块
  • __bases__ : 类的所有父类构成元素

执行:

print('Employee.__doc__:', Employee.__doc__)print('Employee.__name__:', Employee.__name__)print('Employee.__module__:', Employee.__module__)print('Employee.__bases__:', Employee.__bases__)print('Employee.__dict__:', Employee.__dict__)

输出:

Employee.__doc__: 所有员工的基类Employee.__name__: EmployeeEmployee.__module__: __main__Employee.__bases__: (<class 'object'>,)Employee.__dict__: {'__module__': '__main__', '__doc__': '所有员工的基类', 'empCount': 2, '__init__': <function Employee.__init__ at 0x0000025F73518550>, 'displayCount': <function Employee.displayCount at 0x0000025F735185E0>, 'displayEmployee': <function Employee.displayEmployee at 0x0000025F73518670>, '__dict__': <attribute '__dict__' of 'Employee' objects>, '__weakref__': <attribute '__weakref__' of 'Employee' objects>}

还有一些Python中的内置方法,在某种情况下,会自动执行。

  • __init__

前面说过的,在实例化的时候,会被调用执行

  • __new__

在__init__触发前自动触发,调用该类时,方法是真正的类构造方法,用于产生实例化对象(空属性)。因此,可以重写__new__方法来控制对象的产生过程

  • __del__

用于当对象的引用计数为0时自动调用。一般被垃圾回收处理时调用。

在class里面,是不是必须使用self?

不一定,比如我们定义”静态类“的时候:

class util: def checkEmployee(emp): if isinstance(emp, Employee): print('Name : ', emp.name, ', Salary: ', emp.salary) else: print('%s不是Employee' % emp)

假如,我们设计了一个工具类util:用来检测传入的参数是不是Employee类型,如果是的话,才进一步处理。

看下面的代码片段:

emp3 = '李四'util.checkEmployee(emp1)util.checkEmployee(emp2)util.checkEmployee(emp3)

输出:

Name : 张三 , Salary: 2000Name : 王五 , Salary: 5000李四不是Employee

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多