day021|python之面向对象进阶1
面向对象进阶
1 继承
1.1 继承入门
1.1.1 继承基础
什么是继承
继承是一种新建类的方式,新建的类称为子类,被继承的类称为父类
继承的特性是:子类会遗传父类的属性和方法
继承是类与类之间的关系
为什么用继承
可以减少代码冗余
1.1.2 类的基本使用
- 不使用继承
class Animal:
def run(self):
print("跑")
def eat(self):
print("吃")
class Dog:
def run(self):
print("跑")
def eat(self):
print("吃")
def bark(self):
print("犬吠")
class Person:
def run(self):
print("跑")
def eat(self):
print("吃")
def work(self):
print("工作")
- 使用继承
class Animal: # Animal作为父类(基类)
head = 1
def run(self):
print("跑")
def eat(self):
print("吃")
# Dog子类和Person子类都继承Animal父类
class Dog(Animal):
def speak(self):
print("狗吠")
class Person(Animal):
def work(self):
print("工作")
dog = Dog()
dog.eat() # 吃
print(dog.head) # 1
1.2 多继承
1.2.1 多继承的基本使用
# class Animal(): # 表示没有继承其他类
class Animal():
def run(self):
print('走路')
class Coder:
def work(self):
print('写代码')
class Person(Animal, Coder): # 可以继承很多
def eat(self):
print("吃饭")
p = Person()
p.run() # 走路
p.work() # 写代码
p.eat() # 吃饭
1.2.2 多继承以后的重复性
查找顺序
对象自己-->类-->父类(先后顺序)
class Animal():
name = '动物'
def run(self):
print('走路')
class Coder:
name = '社畜'
def work(self):
print('写代码')
class Person(Animal, Coder):
name = 'ccc'
def eat(self):
print('吃饭')
p = Person()
p.name = 'zzz'
print(p.name)
# 先看对象自己zzz,没有看类ccc,没有看第一个父类'动物',没有看后一个父类'社畜',没有就报错
1.3 类的类型
1.3.1 新式类
- 如果一个类继承了object,那么这个类就是新式类
- python3中所有类都默认继承object(不写也会继承object类),所有类都是新式类
class Student():
pass
class Teacher(object):
pass
class School(Student, Teacher):
pass
# 查看一个类继承了哪些父类用__bases__
print(School.__bases__) # (<class '__main__.Student'>, <class '__main__.Teacher'>)
print(Teacher.__bases__) # (<class 'object'>,)
print(Student.__bases__) # (<class 'object'>,)
1.3.2 经典类
- 没有继承任何父类的类,叫经典类,只有python2才有
- python2中如果要写新式类,需要手动继承object
# 在python2中
class Student(object): # 新式类
pass
class Teacher(): # 经典类
pass
# py2的语法
print Student.__bases__ # (<class 'object'>,)
print Teacher.__bases__ # ()
- 新式类和经典类的属性查找顺序是不一样的
1.4 继承与抽象
1.4.1 抽象的两个层次
- 将对象中比较像的部分抽取成类
- 将类比较像的部分抽取成父类
1.4.2 继承
- 基于抽象的结果,通过编程语言实现他
- 首先经历抽象这个过程,才能通过继承的方式去表达出抽象的结构
1.4.3 示例
class Animal(object):
def run(self):
print('走路')
class Human(Animal):
def work(self):
print('work')
class Ccc(Human):
pass
print(Ccc.__bases__) # (<class '__main__.Human'>,)
1.5 继承的运用
1.5.1 选课系统
- 有学生类、老师类,学生有分数、老师能修改学生分数
class Person(object):
def __init__(self, name, age, gender):
self.name = name
self.age = age
self.gender = gender
class Teacher(Person):
def change_score(self, obj, score):
obj.score = score
class Student(Person):
def __init__(self, name, age, gender):
Person.__init__(self, name, age, gender)
self.score = 0
ccc = Student('ccc', 20, '男')
print(ccc.__dict__) # {'name': 'ccc', 'age': 20, 'gender': '男', 'score': 0}
# 将zzz的分数改为100分
zzz = Student('zzz', 18, '女')
teacher = Teacher('ttt', 35, '女')
teacher.change_score(zzz, 100)
print('张三的分数是:', zzz.score) # 张三的分数是: 100
# 将ccc分数改为96分
teacher.change_score(ccc, 96)
print('ccc的分数是:', ccc.score) # ccc的分数是: 96
1.5.2 选课系统进阶1.0
1.6 属性查找
1.6.1 对象的属性
- 对象的属性(attribute):指的是对象的属性和方法
class Student:
def __init__(self, name):
self.name = name
def work(self):
print('work')
s1 = Student('ccc')
print(s1.name) # ccc
print(s1.work()) # work None(因为没有返回值,所以打印出来的是None)
1.6.2 案例
- 多层继承关系的属性查找顺序,永远是从最底下开始找起(self.属性)
- 有的情况下ctrl+左键会不准确
class F1(object):
def s1(self):
print('F1:s1s1s1')
def s2(self):
self.__init__()
print('F1:s2s2s2')
class F2(F1):
# def s1(self):
# print('F2:s1s1s1')
def s2(self):
print('F2:s2s2s2')
class F3(F2):
# def s1(self):
# print('F3:s1s1s1')
def s2(self):
self.s1()
print('F3:s2s2s2')
f3 = F3()
f3.s2()
"""
在自己有s1的情况下: F3:s1s1s1 F3:s2s2s2
自己没有s1,向父类找s1: F2:s1s1s1 F3:s2s2s2
父类没有s1,再向父类的父类找:F1:s1s1s1 F3:s2s2s2
"""
1.7 super实现选课系统
class Person(object):
def __init__(self, name, age, gender):
self.name = name
self.age = age
self.gender = gender
class Teacher(Person):
def __init__(self, name, age, gender):
# self.__init__(name, age, gender) #会出现递归调用,最终报错
# super(当前类的类名,当前对象) py3以后括号内可以省略
# super(Teacher, self).__init__()
super().__init__(name, age, gender)
self.salary = 1000
def change_score(self, obj, score):
obj.score = score
class Student(Person):
def __init__(self, name, age, gender):
super().__init__(name, age, gender)
self.score = 0
teacher = Teacher('ccc', 18, '男')
print(teacher.__dict__) # {'name': 'ccc', 'age': 18, 'gender': '男', 'salary': 1000}
s1 = Student('zzz', 18, '男')
print(s1.__dict__) # {'name': 'zzz', 'age': 18, 'gender': '男', 'score': 0}
1.8 多继承条件下的查找顺序
2 派生
2.1 派生基础
- 派生:在子类中新定义的属性和方法,就叫派生
- 父类(基类)、子类(派生类)
class Person: # 父类,基类
def run(self):
print('run')
def speak(self):
print('speak')
class Teacher(Person):
school = 'oldboy' # 派生属性
def teach(self): # 派生方法
print('教课')
2.2 派生的方法
# 派生类中使用父类的属性和方法
class Person: # 父类,基类
school = 'oldboy'
def run(self):
print('run')
def speak(self):
print('speak')
2.2.1 不常用方式
- 可能存在问题(子类中如果已经有了speak方法,就不会使用父类的)
class Teacher(Person):
def speak(self):
print('teacher 的 speak')
def teach(self):
# 需要调用父类的speak方法
self.speak() # 不是常用方式,此时就不会调用父类的
print('授课')
teacher = Teacher()
teacher.teach()
# teacher 的 speak
# 授课
2.2.2 方式一
- 指名道姓使用父类的方法
class Teacher(Person):
def speak(self):
print('teacher 的 speak')
def teach(self):
# 指名道姓用
Person.speak(self) # speak
print('教课') # 教课
# 使用父类的属性
print(Person.school) # oldboy
teacher = Teacher()
teacher.teach()
2.2.3 方式二
- 通过super关键字(super是一个特殊对象,代指父类对象)
class Teacher(Person):
def speak(self):
print('teacher 的 speak')
def teach(self):
super().speak() # speak
print(super().school) # oldboy
teacher = Teacher()
teacher.teach()
day021|python之面向对象进阶1的更多相关文章
- python基础——面向对象进阶下
python基础--面向对象进阶下 1 __setitem__,__getitem,__delitem__ 把对象操作属性模拟成字典的格式 想对比__getattr__(), __setattr__( ...
- python基础——面向对象进阶
python基础--面向对象进阶 1.isinstance(obj,cls)和issubclass(sub,super) isinstance(obj,cls)检查是否obj是否是类 cls 的对象 ...
- Python 3 面向对象进阶
Python 3 面向对象进阶 一. isinstance(obj,cls)和issubclass(sub,super) isinstance(obj,cls)检查是否obj是否是类 cls 的 ...
- python基础-面向对象进阶
一.什么是反射 反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省).这一概念的提出很快引发了计算机科学领域关于应用反射性的研究.它首先被 ...
- python学习------面向对象进阶
一 isinstance(obj,cls)和issubclass(sub,super) isinstance(obj,cls)检查是否obj是否是类 cls 的对象 class Foo(object) ...
- python之面向对象进阶2
封装.property装饰器 封装分为3种情况:封装对象的属性.封装类的属性.封装方法. 封装对象的属性:(在属性名前加双下划线__) class Person: def __init__(self, ...
- python开发面向对象进阶:反射&内置函数
isinstance和issubclass isinstance(obj,cls)检查是否obj是否是类 cls 的对象或者子类的对象 class Foo(object): pass class ba ...
- Python之面向对象进阶------反射(Day26)
一 classmethod class Classmethod_Demo(): role = 'dog' @classmethod def func(cls): print(cls.role) Cla ...
- python之面向对象进阶3
1.isinstace和issubclass 2.staticmethod和classmethod 3.反射(hasattr.getattr.setattr.delattr等四个方法) 4.内置方法 ...
随机推荐
- Vue3 Teleport
为什么需要 Teleport? 以 Dialog 组件为例,通常需要在一个组件中引入 Dialog 组件.然而,有时一部分逻辑属于 Dialog 所在的组件中,从技术角度来看,最好将这一部分移动到根节 ...
- mysql5.5升级5.7(1)
卸载旧版本mysql 当然要记得备份数据库数据啦 1.查看需要卸载的部分: rpm -qa |grep -i mysql 2.开始卸载: yum remove mysql* 接下来是安装新版mysql ...
- django基本内容
1,流程 1.1 了解web程序工作流程 1.2 django生命周期 2,django介绍 目的:了解Django框架的作用和特点 作用: 简便.快速的开发数据库驱动的网站 django的优 ...
- 第15.17节 PyQt(Python+Qt)入门学习:PyQt图形界面应用程序的事件捕获方法大全及对比分析
老猿Python博文目录 老猿Python博客地址 按照老猿规划的章节安排,信号和槽之后应该介绍事件,但事件在前面的随笔<PyQt(Python+Qt)实现的GUI图形界面应用程序的事件捕获方法 ...
- PyQt(Python+Qt)学习随笔:Qt Designer组件属性编辑界面中对话窗QDialog的modal属性
modal属性表示窗口执行show()操作时是以模态窗口还是非模态窗口形式展示,缺省为False,设置该值与QWidget.windowModality的值设置为 Qt.ApplicationModa ...
- 精品工具【音乐下载器(可下载VIP音乐)】
工具信息 更新时间:2020年5月26日00点07分更新内容:1. 增加快捷键2. 细分下载列表清除功能一款可以下载付费音乐的音乐下载器 下载链接:https://nitian1207.lanzous ...
- LeetCode初级算法之数组:189 旋转数组
旋转数组 题目地址:https://leetcode-cn.com/problems/rotate-array/ 给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数. 示例 1: 输 ...
- LeetCode初级算法之数组:26 删除排序数组中的重复项
删除排序数组中的重复项 题目地址:https://leetcode-cn.com/problems/remove-duplicates-from-sorted-array/ 给定一个排序数组,你需要在 ...
- Go-数据类型-字符串-string
字符串 -- string 字符串使用双引号表示 " " 多行或原始字符串(反斜杠失去转义行为)使用 反引号 `` 字符使用单引号表示 ' ',表示单独的字母.中文.数字 字符串转 ...
- 使用darkarmour免杀mimikatz
darkarmour是一个可用来免杀exe的项目,github地址:https://github.com/bats3c/darkarmour 我们使用darkarmour来免杀mimikatz. ./ ...