python入门系列:面向对象

类和对象的创建

经典类 没有继承 object的类

新式类 继承了 object的类

class Money: # 2.x中默认是经典类,3.x中是新式类
pass

class Money(object): # 兼容的一种写法
pass

Money既是类的name属性名,又是一个引用该类的变量

print(Money.name) # Money
xxx = Money
print(xxx.name) # Money
对象

one = Money()
print(one) # <main.Money object at 0x000001555E9534A8>
print(one.class) # <class ‘main.Money‘>
属性相关

对象属性

class Person:
pass
p = Person()

给 p对象增加属性, 所有的属性是以字典的形式组织的

p.age = 18
print(p.age) # 18
print(p.dict) # {‘age‘: 18}
print(p.sex) # AttributeError: ‘Person‘ object has no attribute ‘sex‘

删除p对象的属性

del p.age
print(p.age) # AttributeError: ‘Person‘ object has no attribute ‘age‘
类属性

class Money:
num = 666
count = 1
type = "rmb"

print(Money.num) # 666

对象查找属性,先到对象自身去找,若未找到,根据 class找到对应的类,然后去类中查找

one = Money()
print(one.count) # 1

不能通过对象去 修改/删除 对应类的属性

one.num = 555 # 实际上是给 one 对象增加了一个属性
print(Money.num) # 666
print(one.num) # 555

类属性会被各个对象共享

two = Money()
print(one.num, two.num) # 666 666
Money.num = 555
print(one.num, two.num) # 555 555
限制对象的属性添加

类中的 slots属性定义了对象可以添加的所有属性

class Person:
slots = ["age"] # 只允许添加一个 age属性

p1 = Person()
p1.age = 1
p1.num = 2 # AttributeError: ‘Person‘ object has no attribute ‘num‘
私有化属性

Python没有真正的私有化支持,只能用给变量添加下划线来实现伪私有;通过名字重整机制
属性的访问范围:类的内部-->子类内部-->模块内的其他位置-->其他模块
公有属性 x 的访问范围

类的内部
子类内部
模块内的其他位置
子类内部
受保护属性 _x 的访问范围

类的内部
子类内部
模块内的其他位置(但不推荐)
子类内部(from ... import xxx 不可以访问,要指明all变量)
私有属性 __x 的访问范围

类的内部
子类内部
模块内的其他位置
子类内部(同_x)
保护数据案例

class Person:
def init(self):
self.__age = 18

def set_age(self, age): # 错误数据的过滤
if isinstance(age, int) and 0 < age < 150:
self.__age = age
else:
print("Wrong age value")

def get_age():
return self.__age

p = Person()
print(p.get_age()) # 18
p.set_age(22)
print(p.get_age()) # 22
只读属性

1. 属性私有化 + 属性化 get()方法

class Person(object):
def init(self):
self.__age = 18

可以以使用属性的方式来使用方法

@property
def age(self):
return self.__age
p = Person()
print(p.age) # 18
p.age = 666 # Attribute Error: can‘t set attribute

2. 通过底层的一些函数

class Person:

通过 属性 = 值 的方式来给一个对象增加属性时,底层都会调用这个方法,构成键值对,存储在 dict字典中

可以考虑重写底层的这个函数,达到只读属性的目的

def setattr(self, key, value):
if key == "age" and key in dict:
print("read only attribute")
else:
self.dict[key] = value
方法相关

方法的划分

实例方法
类方法
静态方法
class Person:
def instance_fun(self): # self: 调用对象的本身,调用时不用写,解释器会传参
print("instance method", self)

@classmethod
def class_fun(cls): # cls: 类本身
print("class method", cls)

@staticmethod
def static_fun():
print("static method")
所有的方法都存储在类中,实例中不存储方法
类方法和静态方法无法访问实例属性
方法的私有化

和变量的私有化思想差不多
class Person:
__age = 18

def __run(self): # 只能在该类中被调用
print("running...")
元类

创建类对象的类(类也是一个对象)
a, s = 8, "123"
print(a.class, s.class) # <class ‘int‘> <class ‘str‘>
print(int.class, str.class) # <class ‘type‘> <class ‘type‘>
type是元类。

通过type元类来创建类,动态创建。也可以用metaclass来指明元类,进行类的创建。
检测类对象中是否有 metaclass属性
检测父类中是否有 metaclass属性
检测模块中是否有 metaclass属性
通过内置的type来创建类
def run(self):
print("run...")

Dog = type("Dog", (), {"count": 0, "run": run})
print(Dog) #
d = Dog()
print(d.count) # 0
print(d.run()) # run...
更加详细的内容,在进高级部分的元类编程讲解

内置的特殊属性

内置的特殊方法(魔法函数)

这里只做一个了解,高级部分会详细地讲解魔法函数。可以理解为在类中实现了这些特殊的函数,类产生的对象可以具有神奇的语法效果。

信息格式化操作

calss Person:
def init(self, n, a):
self.name = n
self.age = a

面向用户

def str(self):
return "name: %s, age: %d" % (self.name, self.age)

面向开发人员

def repr(self):

todo

一般默认给出对象的类型及地址信息等

打印或进行格式转换时,先调用 str()函数,若未实现,再调用 repr()函数

p = Person("Rity", 18)
print(p) # name: Rity, age: 18
res = str(p)
print(res) # name: Rity, age: 18
print(repr(p)) # <main.Person object at 0x000001A869BEB470>
调用操作

使得一个对象可以像函数一样被调用

class PenFactory:
def init(self, type):
self.type = type

def call(self, color):
print("get a new %s, its color is %s" % (self.type, color))

pencil = PenFactory("pencil")
pen = PenFactory("pen")

一下两种使用方式会调用 call()函数

pencil("red") # get a new pencil, ites color is red
pencil("blue") # get a new pencil, ites color is blue
pen("black") # get a new pen, ites color is black
索引操作

class Person:
def init(self):
self.cache = {}

def setitem(self, key, value):
self.cache[key] = value

def getitem(self, key):
return self.cache[key]

def delitem(self, key):
del self.cache[key]

p = Person()
p["name"] = "MetaTian"
...
比较操作

使得自己定义的类可以按照一定的规则进行比较

import functoolspython入门系列:面向对象

原文地址:http://blog.51cto.com/14186420/2349771

时间: 2024-08-26 07:52:10

python入门系列:面向对象的相关文章

Python 入门 之 面向对象的三大特性(封装 / 继承 / 多态)

Python 入门 之 面向对象的三大特性(封装 / 继承 / 多态) 1.面向对象的三大特性: (1)继承 ? 继承是一种创建新类的方式,在Python中,新建的类可以继承一个或多个父类,父类又可以称为基类或超类,新建的类称为派生类或子类. ? 在Python中实现继承非常简单,在声明类的时候,在类名后面添加一个小括号,就可以完成继承关系.单纯的从代码的层面上来看当两个类具有相同的功能或者特征的时候就可以使用继承.提取一个父类,这个父类中编写者两个类相同的部分,然后两个类分别去继承这个类就可以

python入门系列:函数

引言 将一段代码集中到一块,起一个名字,下次可以根据这个名字再次使用这个代码块.作用:方便代码重用分解任务,简化程序逻辑使代码更加模块化函数的参数 所有的传参方式都是传引用,注意列表做参数和数值做参数容易出现的问题. 单个参数 多个参数 定义方式 def funName(arg1, arg2, arg3...):pass 调用方法 funName(arg1, arg2, arg3...) # 形参和实参一一对应funName(arg2=v2, arg3=v3, arg1=v1) # 指明形参的名

python入门系列:Python中一切皆对象

引言 Java语言也是面向对象的语言,但是Python要更加彻底Python的面向对象特性,是它使用起来灵活的根本所在对象的特点 可以赋值给一个变量 函数也是对象 def test(name):print(name) my_func = test # 注意 只写函数名 和 函数名加括号 的区别my_func("MetaTian") # 打印:MetaTian可以添加到集合中去 def plus(a, b):print(a+b) def minus(a, b):print(a-b)fun

Python入门之面向对象编程(二)python类的详解

本文通过创建几个类来覆盖python中类的基础知识,主要有如下几个类 Animal :各种属性.方法以及属性的修改 Dog :将方法转化为属性并操作的方法 Cat :私人属性讲解,方法的继承与覆盖 Tiger :子类定义时调用父类方法(super的使用) Animal python中的一个类中有属性和方法,而二者都分为很多种类型,如下所示 属性分为普通属性和类属性 方法分为普通方法.类方法.静态方法. 具体定义方法和使用见下面的代码和注释,各个属性和方法的使用习惯等见最后的 print_anim

Python入门-初始面向对象

之前我们代码基本上都是面向过程的,今天我们就来初始一下python中一个重要的内容:面向对象 一.面向对象和面向过程(重点理解) 1.面向过程: 一切以事物的流程为核心. 核心是"过程"二字, 过程是指解决问题的步骤.即, 先干什么, 后干什么. 基于该思想编写程序就好比在编写一套流水线,是一种机械式的编程思维. 优点: 负责的问题流程化, 编写相对简单 缺点: 可扩展性差 2.面向对象: 一切以对象为中心.  什么是对象? 不好解释,先解释解释什么是车? 有轱辘, 有方向盘, 有发动

python入门系列:Python基础知识

Python注释 单行注释 这是一个单行注释 print("test")多行注释 '''这里就是python的多行注释方式可以直接分行进行注释操作本质上是字符串'''import thisprint("hello world")特殊注释 #!/usr/bin/python3指定解释器的版本#encoding=utf-8python 2.x解决中文文本乱码Python变量 变量使用 使用之前不用声明:做参数传递时,所有的变量都是引用 定义变量 arg = val a

python入门系列:异常处理

引言 系统内部一开始已经内置了一些特定的错误场景,当我们触发了这个场景时,系统内部就会向外界抛出异常.如果我们没有处理,程序就会停止运行.解决异常 通过条件判断语句在程序内部进行容错检测,避免错误的发生.缺点: 如果要处理的错误太多,会有很多的和业务逻辑无关的代码.捕捉异常,然后再处理 try: 可能出现异常的代码 有异常就会抛出,不会再执行剩下的 try后面的代码 except xxxError as xxx: 出现异常后,而且被捕捉到的代码 except可以写多个,用来捕捉多个不同的异常 e

python入门系列:Python使用虚拟环境

虚拟环境 背景 有两个项目,A和B.都依赖一个模块m,但是他们所需要的版本不一样.默认的情况是,只能安装一个版本的模块m.所以一台电脑上,两个项目无法同时运行. 解决方案 创建一个独立的局部python环境,在这个环境中,安装相关的库,如果有多个项目,则创建多个局部环境.平行宇宙即视感. 虚拟环境准备 想要创建平行宇宙,还得依赖一个三方包:virtualenv安装命令:pip install virtualenv使用虚拟环境 创建一个虚拟环境 使用命令:virtualenv dirname,也可

python入门系列:包和模块

基本概念 模块:将一组功能相关的代码写入一个单独的.py文件中,需要时进行导入,这个文件就是模块.包:有层次的文件目录结构,内部有多个模块或多个子包,一般要有init.py这个文件(3.3+ 的版本不需要).库:完成一定功能代码的集合,完成的功能一般更加广泛,可以是模块,也可以是包.框架:通过框架,可以快速实现解决某一个问题所需的代码骨架,后期进行填充即可.包和模块的作用 造轮子,工具代码,供其他模块使用(模块化编程)划分了变量作用域,解决变量/函数重名的问题包和模块分类 内建的模块:built