Python基础篇-day7

本节目录-面向对象
1 类介绍
1.1 面向对象oo特征
1.2 类的特性
1.3 创建与调用
1.3.1 基本结构
1.3.2 结构说明
1.3.3 对外部提供只读访问接口
1.3.4 析构方法
2 继承
2.1 继承介绍
2.2 横向关系(组合)VS纵向关系(继承)
2.3 内置函数
2.3.1 issubclass
2.3.2 isinstance
2.3.3 hassttr

1 类介绍
1.1 面向对象oo特征
oo=Object Oriented
1、封装---信息隐蔽技术
2、继承---子类自动共享父类之间数据和方法的机制
3、多态---不同对象对同一方法响应不同的行动(不同的class中可以含有相同的函数名,响应根据函数中的定义进行)

1.2 类的特性
封装:
1、防止数据被随意修改; 2、使外部程序不需要关注对象内部的构造,只需要通过此对象对外提供的接口进行直接访问即可;
继承:
通过父类-子类的方式以最简洁的方式实现,不同角色

1.3 创建与调用
1.3.1 基本结构
类创造对象,对象称为类的一个实例(实例对象)
类对象(class、大写字母开头)=属性(变量)+方法(函数)
class Tirle:#python中类以大写字母开头

class Dog(object):
nation = ‘china‘ #公有属性
def __init__(self,name,food): #构造函数、构造方法==初始化函数
self.name = name #成员属性
# self.food = food
self.__heart = ‘namal‘ #私有属性

def wark(self): #类的方法
print(‘%s is dog‘% self.name)
def eat(self,food):
print("%s is eating %s" %(self.name,food))

D = dog(‘sss‘,‘dutou‘) #实例化后产生的对象称为实例
D.wark()
D.eat(‘baozi‘)

1.3.2 结构说明
类-->>实例化-->>实例
self 就是调用当前方法的对象
__init__ #构造方法
返回值为None,强制添加返回值会报错TypeError:__init__() should return None
self.name = name #属性--成员属性 外部可以调用,并且内部方法也可以调用
self.__name = name #私有属性(对外部不可见,内部的方法可以调用)
__private_attr_name = value私有属性
def sayhi() #方法
++++++++++++++++++++++++++
__init__(self)方法:构造方法
返回值为None,强制添加返回值会报错TypeError:__init__() should return None
>>> class ball:
def __init__(self,name):
self.name = name
def kick(self):
print (‘I am %s , who kick me‘ % self.name)
>>> a = ball(‘A‘)
>>> a.kick()
I am A , who kick me
>>> a = ball() #----->>必须添加参数、否则报错
Traceback (most recent call last):
File "<pyshell#29>", line 1, in <module>
a = ball()
TypeError: __init__() missing 1 required positional argument: ‘name‘
添加默认参数:
>>> class ball:
def __init__(self,name=‘null‘):
self.name = name
def kick(self):
print (‘I am %s , who kick me‘ % self.name)
>>> a = ball(‘A‘)
>>> a.kick()
I am A , who kick me
>>> a = ball()
>>> a.kick()
I am null , who kick me
不添加默认参数会报错:
++++++++++++++++++++++++++

1.3.3 对外部提供只读访问接口
def get_heart(self): #比较安全
return self.__heart
强制访问私有属性:
r1._Role__heart

公有属性:所有实例化的对象都可以访问的属性为公有属性(在类中直接定义)
Role.nation = ‘US‘ 更改公有属性
+++++++++++++++++++++++++++++++++
私有变量或者函数:在python中定义私有变量或者函数只需要在变量名或函数名前加上“__”两个下划线
>>> class person():
__name = "a"
def getname(self):
return self.__name
>>> p = person()
>>> p.__name
Traceback (most recent call last):
File "<pyshell#52>", line 1, in <module>
p.__name
AttributeError: ‘person‘ object has no attribute ‘__name‘
>>> p.getname()
‘a‘
伪私有:将变量或者函数改成"_类名__变量名"的形式
>>> p._person__name
‘a‘
+++++++++++++++++++++++++++++++++

1.3.4 析构方法
删除实例化的实例
def __del__(self):
print("del--run")

2 继承
2.1 继承介绍
继承概念的实现方式主要有2类:实现继承、接口继承。
实现继承是指使用基类的属性和方法而无需额外编码的能力;
接口继承是指仅使用属性和方法的名称、但是子类必须提供实现的能力(子类重构爹类方法);

多继承时--继承顺序的区别(py2中才能体现,py3全部使用广度查询的方式进行继承)
新式类,查询使用广度查询,将同级的所有类全部查询完毕才继续往上一层类中查找
经典式类,查询使用深度查询,将纵深的所有类全部查询完毕才继续同一层的其他层中查找

class 子类(基类、父类、超类)
class DerivedClassName(BaseClassName):
……
>>> class parent:
def hello(self):
print (‘old jaksjd parent‘)
>>> class child(parent):
pass
>>> p = parent()
>>> p.hello()
old jaksjd parent
>>> c = child()
>>> c.hello()
old jaksjd paren
注意:如果子类中定义与父类同名的方法或者属性,在调用时调用自己的属性或者方法。
>>> class parent:
def hello(self):
print (‘old jaksjd parent‘)
>>> class child(parent):
def hello(self):
print (‘new jaksjd child‘)
>>> p = parent()
>>> p.hello()
old jaksjd parent
>>> c = child()
>>> c.hello()
new jaksjd child

注意:经典类VS新式类 #建议使用新式类
class Person(object): #new style
super
class Person: #classical style
ParentClass.__init__
#SchoolMember.__init__(self,name,age,sex) #经典类继承写法
super(Teacher,self).__init__(name,age,sex) #新式类继承写法

2.2 横向关系(组合)VS纵向关系(继承)
class tutle:
def __init__(self,x):
self.num = x

class fish:
def __init__(self,x):
self.num = x
class pool:
def __init__(self,x,y):
self.tutle = tutle(x)
self.fish = fish(y)
def print_num(self):
print(‘the totel of tutle is %d in the pool,the totel of fish is %d in the pool!‘ % (self.tutle.num,self.fish.num))
>>> pool = pool(1,10)
>>> pool.print_num()
the totel of tutle is 1 in the pool,the totel of fish is 10 in the pool!

Mix_in
绑定:
python严格要求方法需要有实例才能被调用,这种限制就是python的绑定。

2.3 内置函数
所有的类的统称为:object
2.3.1 issubclass
issubclass(class,classinfo)检查class是否是classinfo的一个子类,是则返回true
1、一个类被认为是自身的一个子类
2、classinfo可以是类对象组成的元组,只要class是其中任何一个候选类的子类,则返回true
>>> class a:
pass
>>> class b(a):
pas
>>> class c :
pass
>>> issubclass(a,b)
False
>>> issubclass(b,a)
True
>>> issubclass(a,a)
True
>>> issubclass(c,b)
False
>>> issubclass(a,object)
True

2.3.2 isinstance
isinstance(object,classinfo)检查一个实例对象object是否属于一个类classinfo,
1、如果第一个参数不是对象,则永远返回false
2、如果第二个参数不是类或者由类对象组成的元组,会抛出TypeError异常
>>> b1 = b()
>>> isinstance (b1,b)
True
>>> isinstance (b1,a)
True
>>> isinstance (b1,(a,b,c))
True

2.3.3 hassttr
attr = attribute:属性
hassttr(object,name)检查一个对象是否有指定的属性
name表示一个属性名,需要用单引号将其括起来,格式为:‘name’
>>> class C:
def __init__(self,x=0):
self.x=x
>>>
>>> c1 = C()
>>> hasattr(c1,‘x‘)
True
>>> hasattr(c1,‘y‘)
False
>>> hasattr(c1,x)
Traceback (most recent call last):
File "<pyshell#26>", line 1, in <module>
hasattr(c1,x)
NameError: name ‘x‘ is not defined
getattr(object,name[,default])返回一个对象中指定的属性的值;如果指定的属性不存在,当
含有default参数时返回默认值,否则返回no attribute ‘name‘
>>> getattr(c1,‘x‘)
0
>>> getattr(c1,‘y‘)
Traceback (most recent call last):
File "<pyshell#28>", line 1, in <module>
getattr(c1,‘y‘)
AttributeError: ‘C‘ object has no attribute ‘y‘
>>> getattr(c1,‘y‘,"您所访问的属性不存在……")
‘您所访问的属性不存在……‘
setattr(object,name,value)设置一个对象中指定属性的值,如果指定的属性不存在则新建属性并赋值
>>> setattr(c1,‘y‘,‘fish‘)
delattr(object,name)删除一个对象中指定的属性,如果指定的属性不存在则抛出AttributeError
>>> getattr(c1,‘y‘)
‘fish‘
>>> delattr(c1,‘y‘)
>>> delattr(c1,‘y‘)
Traceback (most recent call last):
File "<pyshell#36>", line 1, in <module>
delattr(c1,‘y‘)
AttributeError: y
property(fget=None,fset=None,fdel=None,doc=None)用过属性来控制属性
>>> class C:
def __init__(self,size=10):
self.size=size
def getsize(self):
return self.size
def setsize(self,value):
self.size=value
def delsize(self):
del self.size
x=property(getsize,setsize,delsize)
>>> c1=C()
>>> c1.size
10
>>> c1.getsize()
10
>>> c1.x=18
>>> c1.getsize()
18

3 多态

多态性(polymorphisn)是允许你将父对象设置成为和一个或更多的他的子对象相等的技术,赋值之后,父对象就可以根据当前赋值给它的子对象的特性以不同的方式运作。简单的说,就是一句话:允许将子类类型的指针赋值给父类类型的指针。

那么,多态的作用是什么呢?我们知道,封装可以隐藏实现细节,使得代码模块化;继承可以扩展已存在的代码模块(类);它们的目的都是为了——代码重用。而多态则是为了实现另一个目的——接口重用!多态的作用,就是为了类在继承和派生的时候,保证使用“家谱”中任一类的实例的某一属性时的正确调用。

时间: 2024-10-09 10:59:37

Python基础篇-day7的相关文章

Python基础篇(八)

key words:私有变量,类静态变量,生成器,导入Python模块,r查看模块可以使用的函数,查看帮助信息,启动外部程序,集合,堆,时间模块,random模块,shelve模块,文件读取等 >>> class Rectangle: ...     def __init__(self): ...         self.__width = 0 ...         self.__height = 0 ...     def setSize(self,width,height): .

老王python基础篇--python, 视频, 教程, 视频教程, 基础

老王python基础篇 基础篇11-python基本数据结构-元组和集合.rar 基础篇19-python语句与数据结构应用.rar 基础篇21-文本操作应用.rar 基础篇3-虚拟机安装xubuntu开发环境.rar 基础篇17-python语句1.2.rar 基础篇10-python基本数据结构-列表应用.rar 基础篇9-python基本数据结构-列表.rar 基础篇5-python基本数据类型讲解1.1.rar 基础篇18-基础篇综合习题.rar 基础篇8-python基本数据类型习题解

python基础篇

python基础篇 变量命名 >>> name_value='freddy' 1 >>> name_value=freddy 2 Traceback (most recent call last): 3 File "<stdin>", line 1, in <module> 4 NameError: name 'freddy' is not defined **变量的值如果是字符串必须要加引号,否则定义变量会报错 (因为他把变

Python基础篇(三)

元组是序列的一种,与列表的区别是,元组是不能修改的. 元组一般是用圆括号括起来进行定义,如下: >>> (1,2,3)[1:2]     (2,) 如果元组中只有一个元素,元组的表示有些奇怪,末尾需要加上一个逗号: >>> (1,2,3)[1:2]     (2,) >>> 3*(3)      9      >>> 3*(3,)      (3, 3, 3) tuple函数 tuple函数用于将任意类型的序列转换为元组: >&

Python基础篇(七)

加上两个下划线变量或者方法变为私有. >>> class Bird: ...    __song = "spark" ...    def sing(self): ...       return self.__song ... >>> b = Bird() >>> b.sing() 'spark' >>> b.__sing() Traceback (most recent call last): File &qu

Python基础篇(六)

retun空值,后面的语句将不再被执行 >>> def test(): ...    print("just a test!") ...    return ...    print("will not be print") ... >>> test() just a test! 和Java类似,在传递参数时,当参数是字符串,元组时,传递的其实是拷贝,修改实际参数不会影响到形式参数.当参数是对象时,修改实际参数将会影响到形式参数.

Python基础篇(一)

首先需要从Python的官网下载python的安装程序,下载地址为:www.python.org/downloads.最新的版本为3.4.1,下载和操作系统匹配的安装程序并安装即可. 安装好了后,在开始里面应该可以找到Python的相关启动项,如上图所示. Python基础篇(一)

Python基础篇(五)

bool用于判断布尔值的结果是True还是False >>> bool("a") True >>> bool(3) True >>> bool("") False >>> bool(0) False Python中的elif类似于Java中的elseif >>> number = (int)(input("input a number: ")) input

工程脚本插件方案 - c集成Python基础篇

工程脚本插件方案 - c集成Python基础篇 序: 为什么要集成脚本,怎么在工程中集成Python脚本. 在做比较大型的工程时,一般都会分核心层和业务层.核心层要求实现高效和稳定的基础功能,并提供调用接口供业务层调用的一种标准的框架划分.在实际中根据需求会拆分的更细. 外部的表现形式就是一个核心动态库,带着一堆业务业务动态库.通过一个调度程序把这些链接起来,外加一堆配置文件,就形成一个完成的项目. 这种模式在一个团队开发中,工作职责比较容易划分.制定API接口后,开发工作基本可以并行实现,包括