面向对象、类、属性

编程思想 -

​ 程序员在遇到问题解决问题的思维模式

  1. 面向过程编程(穷人思想) - 基本语法,逻辑

  2. 函数式编程(小资思想) - 掌握函数 (遇到问题先想想有没有一个已经存在的函数具备解决这个问题的能力,如果有直接调用。没有就创建一个这样的函数)

  3. 面向对象编程(富豪思想) - 类、对象(变量、函数)

    什么是类、什么是对象

就是拥有相同功能和相同属性的对象的集合。 - 抽象的概念
对象就是类的实例(类具体的表现)

ex:

人是类,具体的一个人就是它的对象,比如:余婷、骆昊
电脑是类,我的桌上这台电脑
杯子是类,我桌上这三个杯子都是它的对象
list是类,[10, 20]是列表的对象

类就是类型、类别

定义类(创建类) - 用代码描述清楚这个类是拥有哪些相同功能和哪些相同属性的对象的集合

功能 - 函数
属性 - 保存数据的变量

语法:
class 类名:
类的说明文档
类的内容

说明:
1)class - 关键字;固定写法
2)类名 - 程序员自己命名
采用驼峰式命名并且首字母大写。(类名大写开头;驼峰式 - 从第二个单词开始单词首字母大写)
3): - 固定写法
4)类的说明文档 - 多行注释
5)类的内容 - 相同功能和相同属性。
由方法(对象方法、类方法、静态方法)和属性(对象属性、类属性)组成
方法 - 定义在类中的函数
属性 - 定义在类中的变量


class Person:
    """人类"""
    num = 61            # num是属性def eat(self):      # eat是方法
    print('吃饭')

def sleep(self):
    print('睡')

3.创建对象

语法: 类名() - 创建指定类对应的一个对象,并且将对象返回

p1 = Person()
p2 = Person()
print(p1)
print(p2)


if __name__ == '__main__':
    pass

1.方法 - 定义在类中的函数用,用来描述具备的功能
类中的方法有三种:对象方法、类方法、静态方法
“”"
1)对象方法
a.怎么定义:将函数直接定义在类中
b.怎么调用:通过对象来调用 - 对象.xxx()
c.特点:自带参数self,通过对象调用对象方法的是参数self不需要传参,

系统自动将当前对象传给self
​ (self,谁调用就指向谁)
d.什么时候用:如果实现函数的功能需要用到对象属性就使用对象方法

2)类方法
a.怎么定义:定义函数前加装饰器**‘@classmethod’**
b.怎么调用:通过类来调用 - 类名.xxx()
c.特点:自带参数cls,调用的时候不需要传参,系统自动将当前类传给cls
d.什么时候用:如果实现函数的功能不需要对象属性需要类就是用类方法

3)静态方法
a.怎么定义:定义函数前加装饰器**‘@staticmethod’**
b.怎么调用:通过类来调用 - 类名.xxx(s
c.特点:没有特点
d.什么时候用: 实现函数功能既不需要对象属性也不需要类

class A:
    def func1(self):
        print(f'self:{self}')
        print('对象方法')

def func11(self, x, y):
    print('对象方法2')  #含参对象方法

@classmethod
def func2(cls):
    print('类方法')

@staticmethod
def func3():
    print('静态方法')

通过对象调用对象方法    
a = A()
b = A()
print(f'a:{a}')

a.func1()
b.func11(200, 200)
a.func11(x=100, y=200)


#通过类调用类方法
A.func2()


#通过类调用静态方法
A.func3()

1.魔法方法

方法名以’_ ‘开头并且以’ _'结尾的自带的方法,就是魔法。
所有的魔法方法都会特定的情况下被自动调用。

常用的魔法方法:__init__方法、__repr__方法

a) repr

打印对象的时候会自动调用对象对应的类中的__repr__方法,来定制打印规则(函数的返回值是什么,对象打印结果就是什么)
返回值必须是字符串!

class A:
    def __repr__(self):
        return 'abc'
    pass

a1 = A()
print(f'a1:{a1}')

a2 = A()
print(f'a2:{a2}')

b) init - 每次创建类的对象的时候会自动调用类中的__init__方法

class B:
 def __new__(cls, *args, **kwargs):
     pass

 def __init__(self):
     print('init方法')


b1 = B()
b2 = B()
class C:
    #在类中添加__init__方法的时候,除了方法名和方法类型不能动,可以随意添加参数和随意添加函数体
    def __init__(self, x, y):
        print('C的init方法', x, y)


#创建类的对象的时候需不需要参数,需要几个参数,由类中__init__方法决定
c1 = C(10, 20)
c2 = C(100, 200)
c3 = C(x=1, y=2)

属性: 分为对象属性和类属性两种

1)类属性
a.怎么创建: 在类中直接定义一个变量,这个变量就是类属性
b.怎么使用: 通过类来使用 - 类.xxx
c.什么时候用: 当属性值不会因为对象不同而不一样的时候就使用类属性

2)对象属性
a.怎么创建: 以’self.属性名=值’的形式定义在类的__init__方法
b.怎么使用: 通过对象来使用 - 对象.属性名
c.什么时候用: 当属性值会因为对象不同而不一样的时候就使用类属性
“”"

class A:
x是类属性
x = 100

class A:
     #x是类属性
    x = 100
#name和num是对象属性
def __init__(self):
    self.name = '小明'
    self.num = 10

#使用类属性
print(A.x)

 #修改类属性的值
A.x = 200
print(A.x)

#使用对象属性
a = A()
print(a.name, a.num)

#修改对象属性的值
a.name = '小花'
a.num = 11
print(a.name, a.num)

练习:定义一个圆的类,拥有属性:半径和圆周率,拥有的方法:求周长和求面积

class Circle:
    pi = 3.1415926
def __init__(self):
    self.r = 1

#类中实现函数功能的时候如果需要的数据是属性,不需要提供额外的参数
def get_area(self):
     self = c1; self = c2
    # 如果需要类属性直接用类来提供
    #如果需要对象属性用self来提供
    return Circle.pi * self.r ** 2

def get_perimeter(self):
    return 2 * Circle.pi * self.r

c1 = Circle()

c2 = Circle()
c2.r = 3#此方法基于未给对象方法传参,不严谨

print(c1.get_area(), c2.get_area())

2.对象属性赋初始值的方式

class Person:
    def __init__(self, name, gender='男'):
        self.name = name        # 使用没有默认值的参数来赋值
        self.age = 1            # 赋固定值
        self.gender = gender    # 使用有默认值的参数来赋值
def __repr__(self):
    return f'name:{self.name}, age:{self.age}, gender:{self.gender}'
    return str(self.__dict__)
p1 = Person('小明')
print(p1.name, p1.age, p1.gender)

p2 = Person('小花', '女')
print(p2.name, p2.age, p2.gender)

练习2:创建一个矩形类(根据生活扩展类的内容)

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

def __repr__(self):
    return f'长度:{self.length}, 宽度:{self.width}, 面积:{self.area()}, 周长:{self.perimeter()}'
    # return f'<{str(self.__dict__)[1:-1]}>'
r1 = Rect(5, 4)
r2 = Rect(10, 7)

print(r1)
print(r2)

1.在面向对象编程的时候,可以直接使用对象来代替字典

 stu1 = {'name': '小明', 'age': 12, 'score': 67}
   stu2 = {'name': '小花', 'age': 19, 'score': 100}


class Student:
    def __init__(self, name, age=18, score=0):
        self.name = name
        self.age = age
        self.score = score
def __repr__(self):
    return str(self.__dict__)
stu1 = Student('小明', 12, 67)
stu2 = Student('小花', 19, 100)
print(stu1, stu2)

2.对象的对象属性支持增删改查
1)查 - 获取属性值
a. 对象.属性 - 获取指定属性的值,属性不存在报错
b. getattr(对象,属性名) - 获取指定属性的值,属性不存在报错
c. getattr(对象,属性名, 默认值) - 获取指定属性的值,属性不存在直接返回默认值

print(stu1.name)
print(getattr(stu1, 'name'))

print(stu1.gender)            # 报错!
print(getattr(stu1, 'gender'))
print(getattr(stu1, 'gender', '男'))

2)增、改
a. 对象.属性 = 值 - 当属性存在的时候修改指定属性对应的值;当属性不存在的是给对象添加属性
b. setattr(对象, 属性名, 值) - 当属性存在的时候修改指定属性对应的值;当属性不存在的是给对象添加属性

print(stu1)     # {'name': '小明', 'age': 12, 'score': 67}

stu1.age = 22
print(stu1)     # {'name': '小明', 'age': 22, 'score': 67}

stu1.gender = '男'
print(stu1)     # {'name': '小明', 'age': 22, 'score': 67, 'gender': '男'}

setattr(stu1, 'study_id', '001')
print(stu1)     # {'name': '小明', 'age': 22, 'score': 67, 'gender': '男', 'study_id': '001'}

setattr(stu1, 'score', '76')
print(stu1)     # {'name': '小明', 'age': 22, 'score': '76', 'gender': '男', 'study_id': '001'}


#attr相关函数可以动态操作对象属性
value = input('请输入你想要查看的属性:')
print(stu1.value)
print(getattr(stu1, value))

  1. del 对象.属性
    delattr(对象, 属性名)
 print(stu1)     # {'name': '小明', 'age': 22, 'score': '76', 'gender': '男', 'study_id': '001'}

del stu1.age
print(stu1)     # {'name': '小明', 'score': '76', 'gender': '男', 'study_id': '001'}

delattr(stu1, 'name')
print(stu1)     # {'score': '76', 'gender': '男', 'study_id': '001'}

判断属性是否存在

  3) hasattr(对象, 属性名)
     print(hasattr(stu1, 'name'))        # False
     print(hasattr(stu1, 'score'))       # True

if not hasattr(stu1, 'name'):
    stu1.name = '小明'

继承

让子类直接用拥有父类的属性和方法

父类就是一个大的类,子类是这个大的类下面的一个小的分类

  1. 继承的语法
    “”"
    class 类名(父类):
    类的说明文档
    类的内容

注意:定义类的时候如果没有写父类,这个类默认继承object(基类)

class Person:  == class Person(object):


class A:
    a = 100
def __init__(self):
    self.b = 10
    self.c = 20

def func1(self):
    print('对象方法')

@classmethod
def func2(cls):
    print('类方法')

@staticmethod
def func3():
    print('静态方法')
   class B(A):
    pass


print(B.a)

x = B()
print(x.b, x.c)

x.func1()

B.func2()
B.func3()

3.子类添加内容
子类在拥有父类的属性和方法的同时,往往需要由属于自己特有的一些属性和方法
1)添加类属性和方法
直接在子类中定义新的类属性和新的方法

2)添加对象属性
需要在子类的__init__方法中通过super()去调用父类的__init__方法来继承父类的对象属性

class C(A):
    m = 11
def __init__(self):
    super().__init__()          # 调用当前类的父类的__init__()
    self.name = '小明'

def func11(self):
    print('C的对象方法')

@classmethod
def func22(cls):
    print('C的类方法')

@staticmethod
def func33():
    print('C的静态方法')

def func1(self):
    print('C的对象方法2')
print(C.a, C.m)

x = C()
print(x.name)
print(x.b, x.c)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Zack_36

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值