当前位置: ManBetXapp > 百科 > 科技 >正文

python class用法理解

人气:311 ℃ /2023-02-25 13:11:14

python中class用法是什么呢?不知道的小伙伴来看看小编今天的分享吧!

1、class的定义及常用称呼:

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

对象:它是类的实例化。

方法:指类中定义的函数。

2、类对象支持两种操作:

属性引用和实例化。

属性引用的语法:obj.属性

类实例化的语法:obj = 类名()

类中方法的调用:obj.方法名()

3、举例:

例1

class student(object): #自定义一个类student

def speak(self): ## 哪个对象调用了这个方法,self就是那个对象;可以把self理解为一个形参

print("%s 说:我今年%s岁" % (self.name, self.age))

john = student() #类student 实例化一个对象john

john.name = "约翰" # 给对象添加属性

john.age = 19

john.speak() # 调用类中的 speak()方法

此时的输出为

约翰 说:我今年19岁

例2

class student(object): # 定义构造方法 有init,有别于自定义类

def __init__(self, n, a): #__init__() 是类的初始化方法;它在类的实例化操作后 会自动调用,不需要手动调用;

self.name = n

self.age = a # 设置属性

def speak(self): # 定义类中的普通方法

print("%s 说:我今年%s岁" % (self.name, self.age))

john = student("约翰",19) #类student 实例化一个对象john

john.speak() # 调用类中的 speak()方法

最后的输出同上个例子

在python中使用__开头 并以__结尾的方法,称之为魔法方法;

init(self) 是类的初始化方法,也称构造方法,是一种特殊的魔法方法; init(self)在实例化后,会自动调用,而不用手动调用,所以一般把属性设置在_init__()里;

常用到的魔法方法还有:str(self) 、 del(self)等。

4、类的继承以及super,self的使用:

子类继承父类,即子类拥有了父类的属性和方法。

python中类的初始化都是__init__()。所以父类和子类的初始化方式都是__init__()

但是如果子类初始化时没有这个函数,那么它便调用父类的__init__();(对应例input1)

如果子类种调用了父类的init,但自己又定义了自己的init,那么就会覆盖父类的初始化函数,只显示子类自己的初始化。(对应例input2)

input1:

class Animal(object):

def __init__(self):

self.name = "我是父类"

class Panda(Animal):

def __init__(self):

super().__init__() #使用super的方式来显示调用父类的__init__()函数

super(Panda, self).__init__() # 第二种super初始化的方式

if __name__=="__main__":

panda = Panda() #实例化Panda

print(panda.name)

output1:

我是父类

input2:

class Animal(object):

def __init__(self):

self.name = "我是父类"

class Panda(Animal):

def __init__(self):

super().__init__()

self.name = "panda"

if __name__=="__main__":

panda = Panda()

print(panda.name)

output2:

panda

2. self和super的区别:

(1) self是首先调用自身的方法如果自身没有再去父类中找;super是直接从父类中找方法

(2)self是类(可以理解为形参),super是预编译指令

反正要继承父类,直接上super就ok了

input3:

class Animal(object):

def __init__(self):

self.name = "我是父类"

def A(self): #父类中的A方法

print("父类的A方法")

class Panda(Animal):

def __init__(self):

super().__init__()

self.myname = "panda"

def A(self): #子类中的A方法

print("子类的A方法")

def B(self):

self.A() #self调用A

super().A() #super调用A

if __name__=="__main__":

panda = Panda()

panda.B() #通过B函数来调用A方法,查看self和super的区别

output3:

子类的A方法#我们说过self是先从自身找方法,没有再去父类找

父类的A方法#而super则是直接从父类中找

以上就是小编今天的分享了,希望可以帮助到大家。

python中class的用法

Python学习基础篇 -7:Python中的类(class)

Python学习基础篇 -7前言:本专栏以Python为主题,并尽可能保持每星期两到三更,直到将Python的基础知识浅析和讲解完毕,同时,有一定基础的同学可以移步 Python实战专栏 。

第七篇:Python中的类(class)

  1. 类的必要性

俗话说,物以类聚,人以群分。聚合的好处之一是管理方便,比如有50个学生是你的管理目标,那假设他们都分散在各个班里,如此一来就会造成管理上的极大不便。而聚合无疑是一个提高管理体验的好方法。将这些学生聚合在一起之后,就可以很方便地对其进行操作,例如叫小王去搬作业,让小李去扫地......Python中的类就类似于班级这样的聚合体。

  1. 类(class)张什么样

让我们来看看这货的样子吧

class MyClass: def __init__(self,class_name): print(class_name '成立了!') def student_register(self,names,date): for name in names: print('欢迎' name '同学' '于' date '来学校报到!') def study(self,task): print('今天的学习任务是: ' task) def have_a_test(self,test_name): print('学习了这么久,同学们今天要进行:' test_name) def review(self,content): print('期末考试快到了,同学们需要复习这些内容:' content) def take_the_final_exam(self,student_count,date): print('今天 ' date ' 是举行期末考试的日子,本班级共有 ' str(student_count) ' 名同学参加期末考试!') def make_a_summary(self,name,content): print('下面有请' name '同学对本学期进行总结') print('同学们好,很荣幸能站在台上给同学们做一次本学期的总结,我的总结如下:' content)# 创建班级,会调用class里面的 __init__方法,这个方法里面的self是这个类本身,传递参数的时候忽略她,例如:# def __init__(self,name) 那只需要传递 name 这个参数,后面也是如此M = MyClass('高一(1)班')names = ['李明','王浩']student_count = len(names)M.student_register(names,'2020年9月1日')M.study('集合的概念')M.have_a_test('集合知识小测')M.review('集合、基本初等函数性质、向量')M.take_the_final_exam(student_count,'2021年1月2日')M.make_a_summary('李明','同学们这学期表现得非常好!')

  1. 类的结构剖析

类的定义方式=>通过关键字class 类的名称,例如最简单的一个

class A: def __init__(self): print('成功实例化类')

进行类构造时,一般会有一个 init方法(这里双首尾双下滑线打不出来),这个方法在类被实例化时会被执行,例如第一段代码中的类的实例化就是创建具体的某一个班级,实例化后会执行init方法,即对每一个报到的学生表示欢迎。

类的实例化方法: 实例名称 = 类名(参数1,参数2)

例如上面的代码,创建及实例化代码方式为:

class A: def __init__(self): print('成功实例化类A')a = A()

上面的a是实例化的名称,A是类名,实例化需要传递的参数为0个,如需传递多个参数,详见第一段代码。

  1. 类的继承

继承的必要性:假设你已经有了一个类,但是某一天你需要搞一个新的聚合,但是大部分要聚合的东西跟之前的差不多,如果重新写代码无疑是浪费精力的,所以有一个好办法就是继承原有的东西,然后在此基础上增加新的功能或改写旧的东西。

继承的简单示例

class A: def __init__(self): print('成功实例化类') def eat(self): print('我喜欢吃苹果')class B(A): def eat(self): print('我不喜欢吃苹果,我吃香蕉')a = A()b = B()最后,鉴于本系列文章属于基础类,故此没有讲得特别深入,本系列到此就告一段落了,后面的重心会转移到实战专栏,帮助大家更好地运用 Python ,欢迎有疑惑或者对文章有所见解的同学在评论区讨论噢!

搜索更多有关“ python class用法理解”的信息 [百度搜索] [SoGou搜索] [头条搜索] [360搜索]
CopyRight © 2008-2024 ManBetXappAll Rights Reserved. 手机版