day13类和对象

1. 类的定义

1.1 什么是类、什么是对象

  1. 官方定义
    类就是拥有相等功能和相同的属性的对象的集合 -- 抽象的
    对象就是类的实例 -- 具体
  2. 生活角度看类和对象
    如果人是类,余婷就是对象、骆昊也是对象
    如果电脑是类,我桌上的这两台电脑就是对象

1.2 类的声明

1)语法
class 类名:
类的内容

2)说明
class - 声明类的关键字
类名 - 标识符,不能是关键字
见名知义,采用驼峰式命名(采用通过单词首字母大写的方式来区分不同的单词),首字母大写
: - 固定写法
类的内容 - 主要包含: 类的说明文档、属性(普通的变量)、功能(函数/方法)

1.3 对象怎么声明

对象 = 类() - 创建指定的类对应的对象

1.4 类中的方法

  1. 什么是方法:声明在类中的函数就叫方法
  2. 类中的方法有三种:对象方法、类方法、静态方法
    a. 对象方法: 直接声明在类中的函数
    有默认参数self,通过对象调用的时候这个参数不用传参,因为系统会自动将当前对象传递给self。
    (self,当前对象 - 谁调用self就指向谁,当前类的对象能做的事情self都能做)
    通过类的对象来调用: 对象.对象方法()

b.类方法: 声明函数前加@classmethod
有默认参数cls, 通过类调用的时候这个参数不用传参,因为系统会自动将当前类传递给cls
(cls,当前类 - 谁调用就指向谁,当前类能做的事情cls都能做)
通过类来调用: 类.类方法()

c.静态方法:声明函数前加@staticmethod
没有默认参数
通过类来调用: 类.静态方法()

# 声明一个Person类
class Person:
    """人类"""
    # =========属性==========
    # =========方法==========
    # ===============对象方法============
    def eat(self, food):
        # self = p1, food = '面条'
        # self = p2, food = '火锅'
        print('self:', self)
        print('人吃'+food)
        self.study('python')

    def study(self, type):
        # self = p1, type = 'python'
        # self = p2, type = 'python'
        print('学习'+type)

    # ===============类方法================
    @classmethod
    def destroy(cls):
        # cls = Person
        # 通过cls创建对象
        tp = cls()      # tp = Person()
        cls.func1()     # Person.func1()
        print('tp:', tp)
        print('cls:', cls)
        print('人类破坏环境')

    @classmethod
    def func1(cls):
        # cls = Person
        print('临时类方法')

    # ===============静态方法================
    @staticmethod
    def beat_animal():
        print('人类殴打小动物')


# 创建Person类的对象p1
p1 = Person()
p0 = p1
print(p1, p0)
p2 = Person()
print(p2)

# 对象调用对象方法
p1.eat('面条')
# p1.study()
p2.eat('火锅')

# 类调用类方法
print(Person)
Person.destroy()

# 类调用静态方法
Person.beat_animal()

2. 类的初始化

2.1 什么是init方法

init是类默认继承的一个魔法方法,用来初始化类; 本质是对象方法,但是不需要程序员自己调用,会被自动调用。
通过类创建对象的时候(通过构造方法创建对象),系统会自动调用类中的init方法,并且构造方法中的实参会全部传给init方法
创建对象的时候需不需要参数,需要几个参数,看这个类的init方法

(了解)声明类的时候系统会自动给我们创建一个函数,这个函数的函数名和声明的类的类名一样,这个函数叫构造方法。
函数中会先在内存中开辟空间创建对象,然后用创建的对象去调用类的init方法,最后才将对象返回

class Person:
    def __init__(self, name, age):
        print(self, name, age)
        print('init方法')

# def Person(*args, **kwargs):
#     t = 创建对象
#     t.__init__(*args, **kwargs)
#     return t


print('===========')
p1 = Person('yuting', 18)
print(p1)
print('===========')

p2 = Person('小明', age=20)
# ========模拟构造方法和init的关系=========
def yt_init(name, age):
    print('自己的init', name)


def yt_Person(*args, **kwargs):
    # args = ('yuting',)  kwargs={}
    yt_init(*args, **kwargs)


yt_Person('xiaoming', 20)
yt_Person(name='张三', age=21)
yt_Person('xiaohua', age=9)

3. 类的属性和方法

3.1 属性

类中的属性分为:对象属性和字段
1)字段: 直接声明在类中变量就是字段;
字段要通过'类.字段'的方式来使用;
当属性的值不会因为对象不同而不同,这种属性就可以声明成类的字段

2)对象属性: 在init方法中,以'self.属性 = 值'的形式声明;
对象属性要通过'对象.属性'的方式来使用
当属性的值会因为对象不同而不同的时候,使用对象属性

class Dog:
    """狗"""
    # =========字段==========
    numbers = 10

    # =========对象属性========
    def __init__(self, name1, color1='黄色', gender1='公'):
        self.name = name1
        self.color = color1
        self.gender = gender1
        self.age = 0


# 使用类的字段
Dog.numbers = 100
print(Dog.numbers)

# 使用对象属性
dog1 = Dog('大黄')
print(dog1.color)
print(dog1.gender)
print(dog1.age)

dog2 = Dog('财财', color1='灰色')
print(dog2.color)
print(dog2.gender)
print(dog2.age)
# 练习:  声明一个学生类,拥有属性:名字、电话、年龄、学号  拥有功能: 学习(打印XXX在学XXX)
class Student:

    number = 1000

    def __init__(self, name, tel='', age=0):
        self.name = name
        self.tel = tel
        self.age = age
        self.num = '0000'

    def study(self, subject: str):
        print(Student.number)
        print(self.name+'在学'+subject)


stu = Student('小明', '182323332', 12)
stu.study('python')

stu1 = Student('小花', '182323332', 12)
stu1.study('H5')
# 写一个矩形类,有属性:长和宽   方法:求面积、求周长
class Rect:
    """矩形"""
    def __init__(self, length, width):
        self.length = length
        self.width = width

    def area(self):
        return self.length * self.width

    def perimeter(self):
        return (self.length + self.width)*2


r1 = Rect(100, 56)
print(r1.area(), r1.perimeter())

3.2 声明类的时候方法的选择(记住)

1)对象方法: 实现函数的功能需要对象属性的时候,就使用对象方法
2)类方法: 实现函数的功能不需要对象属性,但是需要类的相关的操作,就使用类方法
3)静态方法: 实现函数的功能既不需要对象属性,也不需要类相关的操作,就使用静态方法

4. 属性的操作

python中的对象属性支持增、删、改、查

class Dog:
    def __init__(self, name):
        self.name = name
        self.age = 0


dog1 = Dog('大黄')
dog2 = Dog('财财')

4.1 查

a. 对象.属性 - 获取指定对象指定属性对应的值, 如果属性不存在会报错
b. getattr(对象, 属性名, 默认值) - 获取指定对象指定属性对应的值;
当属性不存在有默认值的时候不报错,返回默认值。没有默认值的时候报错

print(dog1.name)
# print(dog1.name2)   # AttributeError: 'Dog' object has no attribute 'name2'

print(getattr(dog1, 'name2', 100))

4.2 增、改

a. 对象.属性 = 值 - 当属性不存在就添加属性,当属性存在修改属性的值
b. setattr(对象, 属性名, 值) - 当属性不存在就添加属性,当属性存在修改属性的值

dog1.gender = '雌'
print(dog1.gender)
dog1.name = '贝贝'
print(dog1.name)

a_name = 'color'
setattr(dog1, 'color', '白色')
print(getattr(dog1, 'color'))
setattr(dog1, 'name', '金金')
print(dog1.name)

4.3 删

a. del 对象.属性
b. delattr(对象, 属性名)

del dog1.name
# print(dog1.name)    # AttributeError: 'Dog' object has no attribute 'name'
delattr(dog1, 'age')
# print(dog1.age)       # AttributeError: 'Dog' object has no attribute 'age'

注意: 对象属性的增删改查只针对单个对象

# print(dog2.gender)   #  AttributeError: 'Dog' object has no attribute 'gender'

print(dog2.name, dog2.age)

你可能感兴趣的:(day13类和对象)