python中Class(类)的超详细说明

Class 类

用来描述具有相同的属性和方法对象的集合。它定义了该集合中每个对象所共有的属性和方法。对象是类的实例

一个人(身高:一米八)要吃饭、喝水、睡觉;
一只老虎(体重:300斤)要奔跑、洗澡、捕猎。

一、名词定义

  • 类(Class): 用来描述具有相同的属性和方法的对象的集合。它定义了该集合中每个对象所共有的属性和方法。对象是类的实例。
  • 方法: 类中定义的 函数 。
  • 类变量: 类变量在整个实例化的对象中是公用的。
    • 一般位置 :类变量定义在类中且在函数体之外。
    • 固有属性由类变量表示。
    • 类变量通常不作为实例变量使用。
    • 对类变量的修改会影响到类的所有实例。
  • 数据成员: 类变量或者实例变量用于处理类及其实例对象的相关的数据。
  • 方法重写: 如果从父类继承的方法不能满足子类的需求,可以对其进行改写,这个过程叫方法的覆盖(override),也称为方法的重写。
  • 实例变量:
    • 一般位置 :在类的 __init__ 声明中。
    • 属性 是用变量来表示的,这种变量就称为实例变量,且一般是自定义属性
  • 局部变量:
    • 一般位置 :定义在方法中的变量。
    • 只作用于当前实例(对象)的类。
    • 一旦函数或方法执行完毕,局部变量就会被销毁。
    • 局部变量与类本身无关,无论是在类的内部还是外部定义的方法中,都可以有局部变量。
  • 继承: 即一个派生类(derived class)继承基类(base class)的属性和方法。继承也允许把一个派生类的对象作为一个基类对象对待。
  • 实例化: 创建一个类的实例,即创建一个类的具体对象。
    • 实例是可以更改、删除原属性的。
  • 对象: 通过类定义的数据结构实例,实例即对象。对象包括两个数据成员(类变量和实例变量)和方法。

二、先睹为快

通俗举例:

#通俗举例:
定义一个人(男性)要吃饭、喝水、睡觉;
现在有个具体的人,他被赋予上述定义,所以他便是男人,会吃饭,会喝水,会睡觉。
#类名:一个人
#属性:男性
#方法:吃饭、喝水、睡觉
#对象:这个具体的人(赋予这个人相同的属性、方法的过程叫“实例化”)
  • 无 __init__ 代码举例(有 __init__ 的后面会写):

    class Calculator:             # Calculator:类名
        name = 'Good calculator'  # name:类变量(固有属性)
        price= 18                 # price:类变量(固有属性)
        def add(self,x, y):       # add():方法
            result=x+y            # result:局部变量
            print(result)
        def minus(self, x, y):    # minus():方法
            result=x-y            # result:局部变量
            print(result)
        def times(self, x, y):    # times():方法
            print(x*y)
        def divide(self, x, y):   # divide():方法
            print(x/y)
    cal1 = Calculator()           # ☆实例化(cal1也有了相同的属性和方法)
    ————————————————————————————————————————————————————————————————————————————————————————————
    >>> cal1.name                 ----->'Good calculator'
    >>> cal1.add(1,2)             ----->3
    >>> cal1.price                ----->18
    >>> cal1.price=25
    >>> cal1.price                ----->25 # 实例的属性可以修改
    

三、详细解释

(1)self

  • 在用 def 定义方法时,第一个参数一定得是 self 。

  • self 代表的是类的实例(对象),本质是代表当前对象的地址,不是类;而 self.class 则指向类。

    请看 VCR :

    class Test:
        def prt(self):
            print(self)
            print(self.__class__)
     
    t = Test()
    t.prt()
    ————————————————————————————————————————————————————————————————————————————————————————————
    #输出结果为(两个 print 的结果):
    <__main__.Test instance at 0x100771878>
    __main__.Test
    
  • self 不是 python 关键字,可以把它换成别的单词,但仍强烈建议使用 self。

(2)方法

  • 在类的内部,使用 def 关键字来定义一个方法。
  • 与一般函数不同,类的方法在定义时必须包含参数 self,且为第一个参数,self 代表的是类的实例。
  • self 不是 python 的关键字,所以可以用别的单词来代替 self 。
    但按照惯例,最好就用 self 。
def add(self,x,y) # add即为方法名,x和y为调用该函数需要输入的参数
    result=x+y

__init__

一种内置的方法,可称之为“构造方法”,初始化(Initialize的缩写)

前后各两个下划线

在实例化时,会自动调用,用来初始化自定义属性

  • 有 __init__ 代码举例(没给出默认自定义属性,实例化时需要手动给出):

    下方代码要注意一点,自定义属性是 hight 这些,不是 hig 这些,hig 只是输入参数。

    class Calculator:             # Calculator:类名
        class_variable = "I am a class variable" # 这是一个类变量(固有属性)  
        name = 'Good calculator'  # name:类变量(固有属性)
        price= 18                 # price:类变量(固有属性)
                                                    #*****************************
        def __init__ (self, hig, wid, wei):         #              *
            self.hight = hig      # hight:实例变量(自定义属性)      *
            self.width = wid      # width:实例变量(自定义属性)      *
            self.weight = wei     # weight:实例变量(自定义属性)     *
                                                    #*****************************
        def add(self,x, y):       # add():方法
            result=x+y            # result:局部变量
            print(result)
        def minus(self, x, y):    # minus():方法
            result=x-y            # result:局部变量
            print(result)
        def times(self, x, y):    # times():方法
            print(x*y)
        def divide(self, x, y):   # divide():方法
            print(x/y)
    ————————————————————————————————————————————————————————————————————————————————————————————
    #先运行程序
    >>> cal2 = Calculator(1,5,12) #实例化时,一定要给出自定义属性的内容
    >>> cal2.name                 ----->'Good calculator'
    >>> cal2.hight                ----->1
    >>> cal2.add(1,2)             ----->3
    >>> cal2.price                ----->18
    >>> cal2.price=25
    >>> cal2.price                ----->25 # 实例的固有、自定义属性都可修改
    
  • 有 __init__ 代码举例(给出默认自定义属性):

    ...#同上
                                                    #*******************
        def __init__ (self, hight=1, width=5, weight=12):      *
            self.hight = hight    # hight:自定义属性            *
            self.width = width    # width:自定义属性            *
            self.weight = weight  # weight:自定义属性           *
                                                    #*******************
        ...#同上
    ————————————————————————————————————————————————————————————————————————————————————————————
    #先运行程序
    >>> cal2 = Calculator() #实例化时,不用再给出自定义属性,除非要修改
    
  • super().__init__() 的功能与用法

    在Python中,super() 函数是用于调用父类(超类)的一个方法。在类的构造函数(__init__)中使用super().__init__()是一种常见的做法(特别是在多重继承的情况下,它确保了父类被正确地初始化,但是这里不过多介绍多重继承)。
    ————
    python3 的 super() 函数就是此格式,比 python2 的 super() 函数要精简。

    • 用法:

      假设我们有一个基类(父类)和一个派生类(子类),子类在初始化时,可能需要父类的一些已经设置好的属性或方法,我们希望在子类初始化时也初始化基类。这时就可以使用super().__init__()

    • 示例:

      class Parent:  
          def __init__(self, name):  
              self.name = name  
              print(f"Parent with name: {self.name}")  
        
      class Child(Parent):  
          def __init__(self, name, age):  
              super().__init__(name)  # 调用父类的__init__方法  
              self.age = age  
              print(f"Child with name: {self.name} and age: {self.age}")  
        
      # 使用子类  
      child_instance = Child("Alice", 10)
      ---------------------------------------------------------------------------------------------------------------
      # 运行结果
      Parent with name: Alice  
      Child with name: Alice and age: 10
      

      这里用到了 f-string 字符,感兴趣的可以上网搜搜,或者直接问 GPT 。

__call__

一种内置的方法,前后各两个下划线。
这个内置方法,有点多此一举的感觉,不过有些妙用,需要慢慢体会…

该内置函数的作用是:
“实例可以直接当函数用,且其效果就是 __call__ 函数的效果”,此时, __call__ 函数的输入参数,就是实例的输入参数。
具体使用代码见下方运行程序结果:

class Calculator:             # Calculator:类名
    class_variable = "I am a class variable" # 这是一个类变量(固有属性)  
    name = 'Good calculator'  # name:类变量(固有属性)
    price= 18                 # price:类变量(固有属性)
                                                #*****************************
    def __init__ (self, hig, wid, wei):         #              *
        self.hight = hig      # hight:实例变量(自定义属性)      *
        self.width = wid      # width:实例变量(自定义属性)      *
        self.weight = wei     # weight:实例变量(自定义属性)     *
                                                #*****************************
    def __call__ (self, test_value):
    	print("Output is:" + str(test_value))

    def add(self,x, y):       # add():方法
        result=x+y            # result:局部变量
        print(result)
————————————————————————————————————————————————————————————————————————————————————————————
#先运行程序
>>> cal2 = Calculator(1,5,12) #实例化时,一定要给出自定义属性的内容
>>> cal2.name                 ----->'Good calculator'
>>> cal2(111)                 -----> Output is:111

多加一嘴:其余自命名方法(函数)的调用方式为 实例名.方法名() 。

(3)继承

就是先定义了一个 基准类,后面想再定义一个 派生类,该派生类想沿用基准类的属性和方法,这种沿用过程就叫“继承”。

子类(派生类 DerivedClassName)会继承父类(基类 BaseClassName)的属性和方法。

  • 单继承:

    • 当基类和派生类 处于同一个模块中 时:

      class 派生类名(基类名):
          ...
          代码块
          ...
      
    • 当基类和派生类不在同一个模块中时,需要从基类所在模块导入基类:

      • 写法一(仅导入基类):

        #假设基类 BaseClassName 在模块 modname 中
        from modname import BaseClassName  
          
        class DerivedClassName(BaseClassName):  
            ...
            代码块
            ...
        
      • 写法二(直接导入基类所在模块):

        #假设基类 BaseClassName 在模块 modname 中
        import modname  
          
        class DerivedClassName(modname.BaseClassName):  
            ...
            代码块
            ...
        

    示例:

    #类定义
    class people:
        #定义基本属性
        name = ''
        age = 0
        #定义私有属性,私有属性在类外部无法直接进行访问
        __weight = 0
        #定义构造方法
        def __init__(self,n,a,w):
            self.name = n
            self.age = a
            self.__weight = w
        def speak(self):
            print("%s 说: 我 %d 岁。" %(self.name,self.age))
     
    #单继承示例
    class student(people):
        grade = ''
        def __init__(self,n,a,w,g):
            #调用父类的构函
            people.__init__(self,n,a,w)
            self.grade = g
        #覆写父类的方法
        def speak(self):
            print("%s 说: 我 %d 岁了,我在读 %d 年级"%(self.name,self.age,self.grade))
     
    s = student('ken',10,60,3)
    s.speak()
    ————————————————————————————————————————————————————————————————————————————————————————————
    #输出结果为:
    ken 说: 我 10 岁了,我在读 3 年级
    
  • 多继承:

    #参考菜鸟教程,基本不用:
    https://www.runoob.com/python3/python3-class.html
    

(4)方法重写

如果父类定义的方法的功能不能满足需求,则可以在子类重写父类的方法。

示例:

class Parent:        # 定义父类
   def myMethod(self):
      print ('调用父类方法')
 
class Child(Parent): # 定义子类
   def myMethod(self):
      print ('调用子类方法')
 
c = Child()          # 子类实例
c.myMethod()         # 子类调用重写方法
super(Child,c).myMethod() #用子类对象调用父类已被覆盖的方法
————————————————————————————————————————————————————————————————————————————————————————————
#输出结果为:
调用子类方法
调用父类方法

四、实例变量、局部变量、类变量的 GPT 解释

在Python的继承机制中,理解实例变量、局部变量、和类变量是非常重要的。这些变量在类及其对象中的作用域和生命周期各不相同。下面是对这些变量的详细解释:

  • 实例变量(Instance Variables)

    实例变量也称为对象变量,它们是在类的实例(即对象)中定义的变量。每个实例都有自己独立的实例变量副本,即使两个实例属于同一个类,它们的实例变量值也可以是不同的。实例变量通常通过类的构造方法(__init__)来初始化。

    class MyClass:  
        def __init__(self, value):  
            self.instance_variable = value  # 这是一个实例变量  
      
    obj1 = MyClass(10)  
    obj2 = MyClass(20)  
      
    print(obj1.instance_variable)  # 输出: 10  
    print(obj2.instance_variable)  # 输出: 20
    
  • 局部变量(Local Variables)

    局部变量是在函数或方法内部定义的变量。它们的作用域仅限于定义它们的函数或方法。一旦函数或方法执行完毕,局部变量就会被销毁。局部变量与类本身无关,无论是在类的内部还是外部定义的方法中,都可以有局部变量。

    class MyClass:  
        def my_method(self):  
            local_variable = "I am a local variable"  # 这是一个局部变量  
            print(local_variable)  
      
    obj = MyClass()  
    obj.my_method()  # 输出: I am a local variable  
    # 在这里,local_variable 已经不存在了
    
  • 类变量(Class Variables)

    类变量是在类级别定义的变量,它们不属于类的任何特定实例。相反,它们被类的所有实例共享。类变量可以通过类本身来访问,也可以通过类的任何实例来访问。当通过实例修改类变量时,这个改变会影响到所有实例,因为所有的实例共享同一个类变量。

    class MyClass:  
        class_variable = "I am a class variable"  # 这是一个类变量  
      
        def __init__(self, value):  
            self.instance_variable = value  
      
        def print_variables(self):  
            print(self.class_variable)  # 通过实例访问类变量  
            print(MyClass.class_variable)  # 直接通过类名访问类变量  
      
    # 修改类变量  
    MyClass.class_variable = "I have been modified"  
      
    obj1 = MyClass(10)  
    obj2 = MyClass(20)  
      
    obj1.print_variables()  # 输出: I have been modified 和 I have been modified  
    obj2.print_variables()  # 输出同上,因为类变量被所有实例共享
    

    注意:尽管可以通过实例访问类变量,但最好通过类名来访问和修改类变量,以避免潜在的混淆。特别是在通过实例修改类变量时,要清楚这样做会影响所有实例共享的类变量值。

总结 

到此这篇关于python中Class(类)的文章就介绍到这了,更多相关python Class类说明内容请搜索恩蓝小号以前的文章或继续浏览下面的相关文章希望大家以后多多支持恩蓝小号!

原创文章,作者:WWFJW,如若转载,请注明出处:http://www.wangzhanshi.com/n/4758.html

(0)
WWFJW的头像WWFJW
上一篇 2024年12月17日 19:25:57
下一篇 2024年12月17日 19:25:59

相关推荐

  • 10个Python常用的损失函数及代码实现分享

    什么是损失函数 损失函数是一种衡量模型与数据吻合程度的算法。损失函数测量实际测量值和预测值之间差距的一种方式。损失函数的值越高预测就越错误,损失函数值越低则预测越接近真实值。对每个…

    2024年12月23日
  • python去除字符strip方法的实现

    .strip() 是 Python 字符串的一个方法,用于去除字符串首尾的空白字符(包括空格、制表符、换行符等)。这个方法非常有用,特别是在处理从文件或用户输入中读取的字…

    Python 2024年12月17日
  • Python命令启动Web服务器实例详解

    Python命令启动Web服务器实例详解 利用Python自带的包可以建立简单的web服务器。在DOS里cd到准备做服务器根目录的路径下,输入命令: python -m Web服务…

    Python 2024年12月24日
  • python实现批量移动文件

    本文通过实例为大家分享了python实现批量移动文件的具体代码,供大家参考,具体内容如下 任务:每个大文件夹下有许多小文件夹,将小文件夹里的pdf文件移动到指定文件夹。如图: 最终…

    2024年12月27日
  • 分享15个令人相见恨晚的Python字符串格式化技巧

    今天,我将向大家分享15个令人相见恨晚的Python字符串格式化技巧,帮你写出更高效、优雅且Pythonic的代码。 1. f'{variabe=}'…

    2024年12月17日
  • python实现员工管理系统

    这是一个简易的员工管理系统,实现最简单的功能: 1.登录用户密码验证(错误三次自动退出) 2.支持文本员工的搜索、添加、删除、修改 3.一级层级多个选项、二级层级多个选项,都支持判…

    2025年1月1日
  • 用python实现PDF解密打印文件

    前言: 我们在打印一些 PDF 文件的时候可能会遇见加密不能打印的情况,需要提供密码才能打印。如果直接在浏览器中浏览 PDF 文件,它不能调取打印功能。但是我们可以换一个思路转换一…

    2024年12月24日
  • Python round函数的基本用法与实例代码

    前言 在Python编程中,round()函数是一个内置函数,用于对浮点数进行四舍五入的操作。这个函数可以对浮点数进行近似处理,使得结果更加清晰和易于理解。本文将深入探讨Pytho…

    Python 2024年12月17日
  • pycharm中安装git遇到的问题及解决

    pycharm安装git遇到的问题 按照视频中所示步骤,安装好git之后,发现没有视频中所示的git选项。 重新检查了一下 也选择了git, 继续查找git没有成功的原因 查看fi…

    2024年12月17日
  • Python万物皆对象理解及源码学习

    万物皆对象 这篇博客的内容主要是针对Python中万物皆对象的理解,对Python的类型、对象体系做一个整体的梳理。 在Python中,一切皆为对象,一个整数是一个对象,一个字符串…

    2024年12月29日

发表回复

登录后才能评论