一. 面向对象的引入
# 人狗大战
def person(name,HP,aggr,sex):
person = {
'name':name, # 昵称
'HP':HP, # 生命值
'aggr':aggr, # 攻击力
'sex':sex
}
return person
alex = person('狗剩儿',100,2,'不详')
nezha = person('哪吒',200,1,'不详')
# 代码精简了,方便增加人物,方便修改,人物更加规范      ------  人的模板
print(alex)
def dogs(name,HP,aggr,kind):
dog = {
'name':name,
'HP':HP,
'aggr':aggr,
'kind':kind
}
return dog
jin = dogs('金老板',1000,1,'泰迪') # 人:攻击技能(打)
def attack(person,dog):
dog['HP'] -= person['aggr']
print('%s被打了,掉了%s滴血'%(dog['name'],person['aggr']))
# 狗:攻击技能(咬人)
def bite(dog,person):
person['HP'] -= dog['aggr']
print('%s被咬了,掉了%s滴血'%(person['name'],dog['aggr']))
# dogs函数、person函数都是定义了一类事物
# 直到调用了函数,赋了值之后才真的有了实实在在的人或狗
bite(jin,alex)
print(alex)
bite(nezha,jin) # 变成了人咬狗了,乱了乱了,怎么办?
于是:
def person(name,HP,aggr,sex):
person = {
'name':name, # 昵称
'HP':HP, # 生命值
'aggr':aggr, # 攻击力
'sex':sex,
} # 人:攻击技能(打)
def attack(dog):
dog['HP'] -= person['aggr']
print('%s被打了,掉了%s滴血' % (dog['name'], person['aggr'])) person['attack'] = attack # 函数名 攻击技能 return person def dogs(name,HP,aggr,kind):
dog = {
'name':name,
'HP':HP,
'aggr':aggr,
'kind':kind
} # 狗:攻击技能(咬人)
def bite(person):
person['HP'] -= dog['aggr']
print('%s被咬了,掉了%s滴血' % (person['name'], dog['aggr'])) dog['bite'] = bite
return dog

alex = person('狗剩儿',100,2,'不详')
nezha = person('哪吒',200,1,'不详')
jin = dogs('金老板',1000,1,'泰迪') jin['bite'](alex)
alex['attack'](jin)
# 面向对象编程
# 所谓模板,就是 类 --- 抽象的,我能知道有什么属性,但不能知道属性具体的值
# jin alex nezha 就是对象 --- 有具体的值,属性都是根据 类 规范的 二. 初识面向对象
字典就是一类数据结构,我一说字典你就知道是那个用{}表示,里面由k-v键值对的东西,它还具有一些增删改查的方法。
但是我一说字典你能知道字典里具体存了哪些内容么?不能,所以我们说对于一个类来说,它具有相同的特征属性和方法。 print(list) # 类
[1,2] # 对象 自定义一个类 # 类名开头一般大写
定义函数时:
def 函数名():
pass

定义类
class 类名: # 可以加括号,可以不加
属性 = 'a'
print(类名.属性) # a
类名的作用,就是操作属性,查看属性
# 人狗大战
class Person:                     # 类名
country = 'China' # 创造了一个只要是这个类就一定有的属性,这个属性叫做 类属性 ,也叫 静态属性
def __init__(self,*args): # 初始化方法,self是对象,必须有
print(self.__dict__) # {} , self就是一个可以存储很多属性的大字典
self.name = args[0] # name 为属性 ,往字典里添加属性的方式发生了一些变化
self.HP = args[1] # HP 为属性
self.aggr = args[2] # aggr 为属性
self.sex = args[3] # sex 为属性
print(self.__dict__) # {'name': '狗剩儿', 'HP': 100, 'aggr': 2, 'sex': '不详'}
print(id(self)) # def walk(self,n): # 方法,一般情况下,必须传self参数,且必须写在第一个,后面还可以传其他参数
print('{} 走走走,走了{}步'.format(self.name,n)) alex = Person('狗剩儿',100,2,'不详') # 对象 # 实例化,,# 类名,可以实例化对象
# print(alex.__dict__) # {'name': '狗剩儿', 'HP': 100, 'aggr': 2, 'sex': '不详'},查看所有属性
# print(alex) # <__main__.Person object at 0x0000018EFBBD58D0>
# print(alex.name) # 狗剩儿
# print(alex.HP) # 100
# print(id(alex)) # 2085337454856 内存地址一样
print(Person.__dict__) # Person里面有walk
Person.walk(alex,5) # 调用方法 :类名.方法名(对象名)
# alex.walk() # 相当于 Person.walk(alex)
alex.walk(5) # 相当于 Person.walk(alex,5) print(Person.country) # 类名 ,可以查看类中的属性,不需要实例化就可以查看 print(Person.__dict__['country']) # China
print(alex.__dict__['name']) # 狗剩儿 # Person.__dict__['country'] = '印度' # 报错 对于类的字典,只能看,不能改
对于对象,可不可以修改?,可不可以删除?
  可以的,可以的
alex.__dict__['name'] = '二哥'
print(alex.__dict__) # {'name': '二哥', 'HP': 100, 'aggr': 2, 'sex': '不详'}
# 但一般不这么改。
# 应该这样改:
print(alex.name) # 二哥
alex.name = '大哥'
print(alex.name) # 大哥
print(alex.__dict__) # {'name': '大哥', 'HP': 100, 'aggr': 2, 'sex': '不详'}
alex.age = 88 # 增加一个属性
print(alex.__dict__) # {'name': '大哥', 'HP': 100, 'aggr': 2, 'sex': '不详', 'age': 88}
总结:
对象 = 类名()
过程:
类名() 首先会创造出一个对象,创建了一个self变量
调用__init__方法,类名括号里的参数会被这里接收
执行__init__方法
返回self
对象能做的事:
查看属性:print(alex.name)、print(alex.HP)
调用方法
__dict__ 对于对象的增删改查操作都可以通过字典的语法进行
类名能做的事:
实例化
调用方法,只不过要自己传递self参数
调用类中的属性,也就是调用静态属性
__dict__,对于类中的名字只能看,不能操作

python学习之老男孩python全栈第九期_day022知识点总结——初识面向对象的更多相关文章

  1. python学习之老男孩python全栈第九期_day017知识点总结——初识递归、算法

    一. 递归函数 如果一个函数在内部调用自身本身,这个函数就是递归函数. 最大递归深度默认是997 -- python从内存角度出发做得限制(而不是程序真的报错),最大深度可以修改 def func(n ...

  2. python学习之老男孩python全栈第九期_day027知识点总结——反射、类的内置方法

    一. 反射 ''' # isinstance class A:pass class B(A):pass a = A() print(isinstance(a,A)) # 判断对象和类的关系 print ...

  3. python学习之老男孩python全栈第九期_day025知识点总结——接口类、抽象类、多态、封装

    一. 接口类 java:面向对象编程 设计模式 -- 接口类 接口类:python原生不支持 抽象类:python 原生支持的 from abc import abstractclassmethod, ...

  4. python学习之老男孩python全栈第九期_day023知识点总结——类和对象命名空间、组合

    一. 类和对象命名空间类里 可以定义两种属性: 1. 静态属性 2. 动态属性 class Course: language = 'Chinese' def __init__(self, teache ...

  5. python学习之老男孩python全栈第九期_day019知识点总结——collections模块、时间模块、random模块、os模块、sys模块

    一. collections模块 在内置数据类型(dict.list.set.tuple)的基础上,collections模块还提供了几个额外的数据类型:namedtuple.deque.Counte ...

  6. python学习之老男孩python全栈第九期_day010知识点总结

    def qqxing(l = []): # 可变数据类型 l.append(1) print(l)qqxing() # [1]qqxing([]) # [1]qqxing() # [1, 1]qqxi ...

  7. python学习之老男孩python全栈第九期_day007知识点总结

    基础数据类型汇总 1. str 2. int 3. list 4. bool 5. dict (1) fromkeys Python 字典 fromkeys() 方法用于创建一个新的字典,并以可迭代对 ...

  8. python学习之老男孩python全栈第九期_day001知识点总结

    1. Python2与Python3的区别: Python2:源码不标准,混乱,重复代码太多: Python3:统一标准,去除重复代码. 编码方式: python2的默认编码方式为ASCII码:pyt ...

  9. python学习之老男孩python全栈第九期_day014知识点总结

    # 迭代器和生成器# 迭代器 # 双下方法:很少直接调用的方法,一般情况下,是通过其他语法触发的# 可迭代的 --> 可迭代协议:含有__iter__的方法( '__iter__' in dir ...

随机推荐

  1. 如何使用robots禁止各大搜索引擎爬虫爬取网站

    ps:由于公司网站配置的测试环境被百度爬虫抓取,干扰了线上正常环境的使用,刚好看到每次搜索淘宝时,都会有一句由于robots.txt文件存在限制指令无法提供内容描述,于是便去学习了一波 1.原来一般来 ...

  2. Log中关于zVideoApp与zChatApp之间的消息传递可以搜索以下字符串

    [CSSBConfIPCAgent::OnMessageReceived]  (这是zVideoApp端的) 和 [CSSBPTIPCListener::OnMessageReceived]      ...

  3. 彻底理解JDK异步

    学而时习之,不亦说乎!                              --<论语> 首发,转载请附原文链接,谢谢. 原文使用MD格式编写,复制进来代码缩成一团了,读者见谅,需要 ...

  4. json兼容ie8

    今天遇到一个问题,后台传递过来的json对象,在前端解析的时候用JSON.parse(result)方法不好使,查了一下是因为ie浏览器的问题.然后在网上翻了翻,找到了这个办法,可以使这个函数在ie中 ...

  5. SqlServer子查询、高级

    子查询:把一个结果集让别人继续分析查询的就叫子查询 子查询如果定义了别名,在查询引用时,必须使用别名 --子查询定义了别名,引用就必须用别名 select id,n from Person,(sele ...

  6. Cpython 支持的线程

    因为Python解释器帮你自动定期进行内存回收,你可以理解为python解释器里有一个独立的线程,每过一段时间它起wake up做一次全局轮询看看哪些内存数据是可以被清空的,此时你自己的程序 里的线程 ...

  7. (转)MySQL多源复制

    原文:https://dev.mysql.com/doc/refman/5.7/en/replication-multi-source.html MySQL多源复制概述 MySQL多源复制使复制从接受 ...

  8. normalize.css源码解析

    什么是normalize.css?  它是为了帮助我们统一各个浏览器的样式和消除bug的css库. 为什么需要normalize.css,有什么好处? 不像一些reset.css,normalize. ...

  9. 天猫消息盒子的CSS实现

    css: body,h2,h3,ul,p{margin:0;padding:0;font-size:12px;} li{list-style: none; } a{text-decoration: n ...

  10. python-哈夫曼树

    #!/usr/bin/python #coding=utf-8 #哈夫曼树创建 class Node(): def __init__(self,value,left=None,right=None): ...