day14

面向对象

编程思想:

  • 1.面向过程的编程 --》 算法、逻辑(数学逻辑)
  • 2.函数式编程 --》函数,模块
  • 3.面向对象编程 --》类和对象(生活逻辑)
n = 100
sum1 = 0
for x in range(n+1):
    sum1 += 1

def add_student():
    pass

class Student_Manager:
    def add_student(self):
        pass

value = input('数字')
if value == '1':
    add_student()

类的声明

1.什么是类和对象

  • 类是拥有相同属性和相同功能的对象集合
    对象 --》 就是类的实例(具体的)

从生活的角度来看类和对象
如果说人是一个类,yt就是一个对象。
如果车是一个类,汽车、自行车这些是这个类的子类,具体的这辆车才是类的对象

2.类的声明

  • 格式:
    class 类名 (父类列表):
    --------类的说明文档
    --------类的内容
    说明:
    class -》 python中声明类的关键字
    类名 -》标识符,不能是关键字;类名使用驼峰式命名,并且是首字母大写;见名知意
    ---------驼峰式命名:如果一个名字有多个单词组成,第一个首字母小写,后面每个首字母大写userName
    ----------PEP8命名规范:如果一个名字由多个单词组成所有字母小写,多个单词之间用下划线隔开 user_name
    (父类列表) --》 继承语法,让声明的类继承括号中的父类。这个结构可以省略,让当前类继承python中的基类:object
    : -》固定结构
    类的说明文档 -》注释,对类进行说明
    类的内容 -》包含属性(数据)和方法(函数)
    ------------------方法:声明在类中的函数
#1.声明Person类,吃饭和睡觉
class Person:
    """人类"""
    def eat(self):
        print('吃饭')
    def sleep(self):
        print('睡觉')

3.对象的声明

  • 对象名 = 类名()
    对象名 -》 变量名
    类名 -》必须是声明过的类
#声明了Person类的对象p1
p1 = Person()
p2 = Person()

对象方法

1.类的内容包含属性和方法,方法分为对象方法、类方法和静态方法

  • 对象方法:直接声明在类中的函数就是对象方法。对象方法都有一个默认参数self,需要使用对象来调用
  • 对象方法的调用:对象.方法名()。调用对象方法的时候,不需要给默认参数self 传参 系统会自动将当前对象传递给self。
  • self谁调用当前的对象方法,self就指向谁.self就是当前类的对象,类的对象能做的事情,self都能做
class Person:
    """人类"""
    def eat(self, name):
        print('self:',self)
        print('吃饭!')
        self.sleep()
    def sleep(self):
        print('睡觉')

p1 = Person()
print('p1',p1)
p1.eat('小明')

p2 = Person()
print('p2:',p2)
p2.eat('小红')

构造方法和init方法

1.构造方法

  • 构造方法就是函数名和类名一样的方法,作用是用来创建对象的。
  • 声明类的时候,系统会自动为这个类创建对应的构造方法
  • 创建对象的过程:调用构造方法在内存中开辟空间创造对象,并且会自动调用init方法去对这个对象进行初始化 最后将地址返回

2.init方法

  • 对象手法
  • 不需要手动调用会自动调用
class Dog:
    """dog类"""
    def __init__(self):
        print('init方法')
dog1 = Dog()

3.带参其他参数的init方法

  • init方法的参数要通过构造方法来传,(构造方法的实参,会传递给init方法的形参)
class Person:
    def __init__(self, name, age):
        print(name, age)

p1 = Person('小红','18')

对象的属性

  • 类的内容包含属性和方法,属性又分为对象属性和类的字段
  • 属性:用来在类中保存数据的变量。
  • 对象属性:属性的值会因为对象不同而不同,这种属性就需要声明成对象属性,例如:人的名字,人的年龄等 对象属性要通过对象来使用

1.对象属性的声明(重点!!)

  • a.必须声明在init方法中,
  • b.声明的格式:self.属性 = 初值

2.使用对象属性:对象.属性

class Person:
    def __init__(self):
        self.name = '张三'
        self.age = 18
        self.sex = '男'

p1 = Person()
print(p1.age)

class Person1:
    def __init__(self, name, age=0, sex='girl'):
        self.name = name
        self.age = age
        self.sex = sex
        self.id = '0001'
p1= Person1('小明',30,'女')
p1.name = 'XiaoMing'
print(p1.name)
p1.id ='0001'
print(p1.id)
p2 =Person1('小红',30,'男')
print(p2.name)
p3 =Person1('小花')
print(p3.sex)

对象属性的增删改查

class Student:
    def __init__(self, name='', age=0, study_id='001'):
        self.name = name
        self.age = age
        self.study_id = study_id

stu1 = Student('小明')

#1.查(获取对象属性的值)

  • 方法1:对象.属性 --》获取指定属性值,属性不存在会报错
print(stu1.name)
#print(stu1.name2)#AttributeError: 'Student' object has no attribute 'name2'
  • 方法2.getattr(对象,属性名,默认值)--》获取指定默认值,如果设置默认值当属性不存在的时候不会报错,并且会将默认值作结果(如果没有设置默认值,属性不存在还是会报错)
print(getattr(stu1,'name',))
print(getattr(stu1,'name2','张三'))
  • 方法3.对象.r__getattribute__(属性名)--》获取指定的属性值,属性不存在会报错
print(stu1.__getattribute__('study_id'))

#增、改

  • 注意:给对象添加属性,只能添加到当前对象中。不会影响当前类的其他对象
  • 方法1:对象.属性 == 值(属性不存在就是添加,存在就是修改)
  • 方法2:setattr(对象,属性名,属性值)
  • 方法3:对象.r__setattr__(属性名,属性值)
stu1.sex = '男'
print(stu1.sex)

#修改
stu1.name = '李四'
print(stu1.name)

#修改
setattr(stu1, 'name', '娜美')
print(stu1.name)

#增加
setattr(stu1, 'name2', 'Lisa')
print(stu1.name2)

#3.删除

  • 注意:删除只删除当前对象的属性,对当前类的其他对象没有影响
  • 方法1:del 属性.对象
  • 方法2:delattr(对象.属性名)
  • 方法3:r__delattr__(属性名)
del  stu1.age
# print(stu1.age)

print(stu1.sex)
delattr(stu1,'sex')

stu1.__delattr__('name')

7.对象的使用

  • python中所有的数据都是对象,所有的变量存储的都是对象的地址
num = int()
print(num.bit_length())

list1 = ['a', 1]
list1.append('abc')
print(list1)

#定制当前类对象打印格式,函数的返回值必须是字符串

  • def str(self):
    return str(self.dict)
class Student:
    def __init__(self, name, age, score):
        self.name = name
        self.age = age
        self.score = score

    #定制当前类对象的打印格式,函数的返回值必须是字符串
    def __str__(self):
         # return str(self.__dict__)
        return 'name:' +self.name+'age:'+str(self.score)

#1.将对象给别的变量赋值

stu1 = Student('xiaoHua', 18, 90)
stu2 = stu1 #赋对象地址
stu3 = copy.copy(stu1) #产生新的对象,将新的地址赋值
stu1.name = '张三'
print(stu2.name)
print(stu3.name)

#2.将对象作为列表的元素

students = [Student('小明', 23, 89), stu3, Student('小红', 18, 67)]
#找到列表students中成绩最好的学生的名字
max1 = students[0].score
name = students[0].name
for stu in students:
    if stu.score>max1:
        max1 = stu.score
        name = stu.name
print(name, max1)

#对列表中的学生按年龄从小到大排序
students.sort(key=lambda item:item.age)
for stu in students:
    print(stu)

max1 = max(students, key=lambda item: item.score)
print('max:',max1)

#1.根据姓名查找指定学生的信息 2.根据姓名修改执行的学生的年龄

name = input('请输入学生的名字')
for stu in students:
    if stu.name == name:
        stu.age = 18
        print(stu)

slots魔法

1.对象属性,类的字段

  • 属性:对象属性,类的字段
  • 类的字段:声明在类里面,函数外面的变量就是类的字段。使用的时候要通过类来使用

2.r__slots__:用来约束当前类的对象的属性有哪些

class Dog:
    #num就是类的字段
    num = 10
    __slots__ = ('color', 'name', 'type','sex')

    def __init__(self, color, name, type):
        self.color = color
        self.name = name
        self.type = type
        self.sex = '公的'
        print(Dog.num)

Dog.num = 100
print(Dog.num)

dog1 = Dog(1, 1, 1)

#1.r__name__

  • 类.r__name__ ->获取当前类的名字
print(Person.__name__,type(Person.__name__))

#2.r__doc__

-类.r__doc__ -》 获取类的说明文档

print(Person.__doc__)
print(int.__doc__)
print(dict.__doc__)

#3.r__class__

my_class = p1.__class__
p2 = my_class('小花', 10, '女')
p2 =Person('小花', 10, '女')
print('===================================')
print(p2.name)
print(Person.num)
print(my_class.num)

#4.dict

  • 类.dict --> 获取当前类的所有类的字段和其对应的值,以字典的形式返回(了解)
  • 对象.dict --> 获取当前对象所有的属性和其对应的值,以字典的形式返回
print(Person.__dict__)
print(p1.__dict__)

#5.module

  • 类.module -> 获取当前类所在的模块
print(Person.__module__)

from datetime import datetime
print(datetime.__module__)

#6.bases

  • 类.bases ->获取当前类的父类,返回的是一个元祖,元祖的元素是类
print(Person.__bases__)
print(p1)

你可能感兴趣的:(day14)