python def __init__(self, name等多参数), def __init__(self)
常见的两种类的定义方式如下
#第一种
class Student:
def __init__(self):#两者之间的区别
self.name = None
self.score = None
##第二种
def __init__(self, name, score):
self.name = name
self.score = score
区别很明显,前者在__init__方法中,只有一个self,指的是实例的本身,但是在方法的类部,包含两个属性,name, score
下面的这个即是在定义方法时,就直接给定了两个参数,
如何实例化
第二个很明显就是直接实例化时,传入相应的参数,而第一种,则需要实例化之后,对属性进行赋值
# student = Student("sansan", 90)
student = Student()
student.name= "sansan"
student.score = 90
# susan = Student("sunny", 78)
susan = Student()
susan.name = "susan"
susan.score = 8
即显示了两种实例化的方法, 注释的部分即是在创建的时候就直接传入参数
两者区别
第一种的区别,他定义了这样一种类,他可以是一个空的结构,比如学生的表,当学生还没有进行考试时,他已经有了学生的姓名和成绩,当新的数据来的时候,可以直接添加进来。这个可以很方便的进行,
而第二种,则需要必须传值,不允许为空。当然第二种对于已有数据的导入是很方便的,在语句上减少了很多
class Student:
def __init__(self):#两者之间的区别
self.name = None
self.score = None
# def __init__(self, name, score):
# self.name = name
# self.score = score
def print_score(self):
print("%s score is %s" % (self.name, self.score))
def get_grade(self):
if self.score >= 80:
return "A"
elif self.score >= 70:
return "B"
else:
return "C"
# student = Student("sansan", 90)
student = Student()
student.name= "sansan"
student.score = 90
# susan = Student("sunny", 78)
susan = Student()
susan.name = "susan"
susan.score = 8
student.print_score()
susan.print_score()
print(susan.get_grade())
print(student.get_grade())
以上是一个很简单的,两者比较,
参考:https://blog.csdn.net/m0_37693335/article/details/82972925
__init__的用法和理解
,两个下划线开头的函数是声明该属性为私有,不能在类的外部被使用或访问。而__init__函数(方法)支持带参数类的初始化,也可为声明该类的属性(类中的变量)。__init__函数(方法)的第一个参数必须为self,后续参数为自己定义。__init__()这个特殊的方法就可以方便地自己对类的属性进行定义,__init__()方法又被称为构造器(constructor)