一、(1)类: 用来描述具有相同的属性和方法的对象的集合。它定义了该集合中每个对象所共有的属性和方法。 (2)对象:是类的实例。
二、self:代表类的实例,而非本类
和普通函数相比,在类中定义函数只有一点不同,就是第一参数永远是类的本身实例变量self,并且调用时,不用传递该参数。除此之外,类的方法(函数)和普通函数没啥区别,你既可以用默认参数、可变参数或者关键字参数(*args是可变参数,args接收的是一个tuple,**kw是关键字参数,kw接收的是一个dict)。
三、__init__用法:构造方法,在类实例化的时候自动调用
在创建实例的时候,把我们认为必须绑定的属性强制填写进去。这里就用到Python当中的一个内置方法__init__方法。
(1)、__init__方法的第一参数永远是self,表示创建的类实例本身,因此,在__init__方法内部,就可以把各种属性绑定到self,因为self就指向创建的实例本身。
(2)、有了__init__方法,在创建实例的时候,就不能传入空的参数了,必须传入与__init__方法匹配的参数,但self不需要传,Python解释器会自己把实例变量传进去。
(3). 在Python中,实例的变量名如果以开头,就变成了一个私有变量(private),只有内部可以访问,外部不能访问
四、调用函数:
Python中函数的定义必须在调用的前面,但是在函数的内部调用一个函数,不用考虑函数的顺序,只要被调用的函数被定义了即可
(1).先定义后,后调用为一般方法:
def add_test(a,b):
return a+b
reslut = add_test(1,2)
print(result)
(2).可以在函数内部调用后面的函数
def add_1(a,b):
return add_2(a,b) #函数内部调用add_2
def add_2(a,b):
return a+b
print ('add_1的调用:',add_1(1,2)) #3
print('add_2的调用:',add_2(2,3)) #5
(3).不可以先调用后定义
print("add的调用",add(a,b))
def add(a,b):
return a+b
以学生类为实例
定义类:
class Student(object):
pass
创建实例:
student = Student()
__init__方法:
class Student(object):
def __init__(self, name, score):
self.name = name
self.score = score
传参:
>>>student = Student("Hugh", 99)
>>>student.name
"Hugh"
>>>student.score
99
self就是指类本身,self.name就是Student类的属性变量,是Student类所有。而name是外部传来的参数,不是Student类所自带的。故,self.name = name的意思就是把外部传来的参数name的值赋值给Student类自己的属性变量self.name。
四.类的方法
既然Student类实例本身可以直接在Student类的内部定义访问数据的函数(方法),这样,就可以把”数据”封装起来。这些封装数据的函数是和Student类本身是关联起来的,称之为类的方法:
class Student(obiect):
def __init__(self, name, score):
self.name = name
self.score = score
def print_score(self):
print "%s: %s" % (self.name, self.score)