day22:初识面向对象

1,类可以理解为是一个模子,可以是代码精简,方便增加实例,方便修改,更加规范,能知道具体的属性,方法,但是不知道具体的值

2,对象有具体的值,属性和技能都是根据类规范的

3, 先有类才有对象

4,面向程序,面向函数,面向对象编程

5,面向对象优点:解决了程序的扩展性,维护和扩展变得简单,大大提高程序的开发效率,缺点,可控性比较差,应用场景:需求经常变化的软件

6,Python中一切皆对象,好比Linux中一切结尾文件

class Person:
    def __init__(self,*args):
        # self是一个可以存储很多属性的大字典
        self.name = args[0] # 王子点里添加属性的方式发生了变化
        self.hp = args[1]
        self.aggr = args[2]
        self.sex = args[3]
    def walk(self):
        print('走走走')

lisa = Person('lisa',100,200,'female')  # 实例化过程,想象序列化
print(lisa.__dict__)
print(Person.__dict__)

# {'name': 'lisa', 'hp': 100, 'aggr': 200, 'sex': 'female'}
# {'__module__': '__main__', '__init__': <function Person.__init__ at 0x10d412840>, 'walk': <function Person.walk at 0x10d4127b8>, '__dict__': <attribute '__dict__' of 'Person' objects>, '__weakref__': <attribute '__weakref__' of 'Person' objects>, '__doc__': None}

7,双下init函数会在实例化的时候自动调用,然后传参,并且会自动返回一个self对象

# 对象 = 类名()
# 过程:
#  类名() 首先会创造出一个对象,创建了一个self变量,创建的过程我们不需要关心,系统自检给创建
# 自动调用init方法,类名括号里的参数会被这里接收 
# 执行init方法,
# 返回sel

8,帮助理解面向对象的一段代码

def Person(*args,**kwargs):
    self = {}
    def attack(self,dog):
        dog['life_value'] -= self['aggressivity']

    def __init__(name,aggressivity,life_value):
        self['name'] = name
        self['aggressivity'] = aggressivity
        self['life_value'] = life_value
        self['attack'] = attack

    __init__(*args,**kwargs)
    return self

egg = Person('lisa',78,10)
print(egg['name'])

9,类里面,我只要已创建一个class的时候,我就拥有了一个self,self等于空字典这个事不需要你去做,别人替你做了,只是你直接拿着这个就可以用了。以点的方式操作然后最后把self返回给对象,新创建的对象,就是self。self里面存储的就是一个字典的关系

class Person:
    def __init__(self,*args):
        # self是一个可以存储很多属性的大字典
        print(self.__dict__)  # {}

        self.name = args[0] # 王子点里添加属性的方式发生了变化
        self.hp = args[1]
        self.aggr = args[2]
        self.sex = args[3]

        print(self.__dict__)  # {'name': 'lisa', 'hp': 100, 'aggr': 200, 'sex': 'female'}


lisa = Person('lisa',100,200,'female')

10,新实例化的对象就是self

class Person:
    def __init__(self,*args):
        # self是一个可以存储很多属性的大字典,
        print(self.__dict__)  # {}

        self.name = args[0] # 只不过往字典里添加属性的方式发生了变化
        self.hp = args[1]
        self.aggr = args[2]
        self.sex = args[3]
        print(id(self))
        print(self.__dict__)  # {'name': 'lisa', 'hp': 100, 'aggr': 200, 'sex': 'female'}


lisa = Person('lisa',100,200,'female')
print(id(lisa))
print(lisa.__dict__) # ID一样,内存地址一样,所以两个就是一样的
运行结果: {}
4417958464 {'name': 'lisa', 'hp': 100, 'aggr': 200, 'sex': 'female'} 4417958464 {'name': 'lisa', 'hp': 100, 'aggr': 200, 'sex': 'female'}

11,调用方法

class Person:
    def __init__(self,*args): # 一般双下init都放在最上面

        self.name = args[0]
        self.hp = args[1]
        self.aggr = args[2]
        self.sex = args[3]
def walk(self): # 这个参数是必须有的,只要是类的方法就得有,这个名字不用self也可以,但是我们不成文的规定都叫self print('hello') lisa = Person('lisa',100,200,'female') print(lisa.__dict__) print(Person.__dict__) # 类的字典里面有个walk,所以我们可以用类来调用试试 # {'name': 'lisa', 'hp': 100, 'aggr': 200, 'sex': 'female'} # {'__module__': '__main__', '__init__': <function Person.__init__ at 0x1007b17b8>, 'walk': <function Person.walk at 0x1007b16a8>, '__dict__': <attribute '__dict__' of 'Person' objects>, '__weakref__': <attribute '__weakref__' of 'Person' objects>, '__doc__': None} # Person.walk() # 提示错误 TypeError: walk() missing 1 required positional argument: 'self' Person.walk(lisa) # 因为Lisa就是self,所以我们传入Lisa # hello # 这种调用有一种简写的方法就是 lisa.walk() # 这个和Person.walk(lisa)效果是一样的

12,总结

# 对象能做的事:
    # 查看属性
    # 调用方法
# 类名能做的事:
    # 实例化
    # 调用方法:只不过要自己调用self参数

13,静态属性

class Person:
    country = 'China'  # 创造了一个只要是这个类就一定有的属性
                       # 类属性,静态属性

    def __init__(self,*args):

        self.name = args[0]
        self.hp = args[1]
        self.aggr = args[2]
        self.gender = args[3]

    def walk(self):
        print('hello')

lisa = Person('lisa',100,200,"female")


print(Person.country) # China
print(Person.__dict__['country'])   # China
print(lisa.__dict__['name']) # lisa
# 类名不可以调用对象的属性,可以查看静态属性,不需要实例化就可以查看

13,修改对象属性,可以通过属性或者字典来修改

    country = 'China'  # 创造了一个只要是这个类就一定有的属性
                       # 类属性,静态属性

    def __init__(self,*args):

        self.name = args[0]
        self.hp = args[1]
        self.aggr = args[2]
        self.gender = args[3]

    def walk(self):
        print('hello')

lisa = Person('lisa',100,200,"female")


print(Person.country) # China
print(Person.__dict__['country'])   # China
print(lisa.__dict__['name']) # lisa
# 类名不可以调用对象的属性,可以查看静态属性,不需要实例化就可以查看

lisa.__dict__['name'] = 'lucy' # 修改成功
print(lisa.__dict__['name'])  # lucy
# __dict__对于对象的属性增删改查都可以通过字典的语法进行,但是正产情况下我们不太这样用,我们一般这样用
lisa.name = 'jack' # 通过属性改,但是不通过字典改
print(lisa.__dict__['name']) # jack
# 这两种修改方式本质上是一样的

14,类属性也就是静态属性的修改不可以通过字典来修改,只能通过属性来修改

class Person:
    country = 'China'  # 创造了一个只要是这个类就一定有的属性
                       # 类属性,静态属性

    def __init__(self,*args):

        self.name = args[0]
        self.hp = args[1]
        self.aggr = args[2]
        self.gender = args[3]

    def walk(self):
        print('hello')

lisa = Person('lisa',100,200,"female")


print(Person.country) # China
print(Person.__dict__['country'])   # China
# Person.__dict__['country'] ='USA'
# TypeError: 'mappingproxy' object does not support item assignment
Person.country = 'USA' # 修改成功

15,大写开头的名字,一般都是给类名用

16,实例,计算圆的面积和周长

from math import pi
class Circle:
    def __index__(self,r):
        self.r = r
        
    def area(self):
        return pi *(self.r**2)
    
    def perimeter(self):
        return 2*pi*self.r
    
c1 = Circle(6)
print(c1.area())
print(c1.perimeter())
    

 

转载于:https://www.cnblogs.com/lisa-blog/p/10200683.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值