class

类定义

语法格式如下:

class ClassName:
<statement-1>
...
<statement-N>

类属性与方法

属性

操作属性

getattr(obj, name[, default])   # 访问对象的属性。
hasattr(obj, name) # 检查是否存在一个属性。
setattr(obj, name,value) # 设置一个属性。如果属性不存在,会创建一个新属性。
delattr(obj, name) # 删除属性。

类的私有属性

__private_attrs

  • 两个下划线开头,声明该属性为私有,不能在类的外部被使用或直接访问。
  • 在类内部的方法中使用时 self.__private_attrs。

类的私有属性实例

#!/usr/bin/python3

class JustCounter:
__secretCount = 0 # 私有变量
publicCount = 0 # 公开变量 def count(self):
self.__secretCount += 1
self.publicCount += 1
print (self.__secretCount) counter = JustCounter()
counter.count()
counter.count()
print (counter.publicCount)
print (counter.__secretCount) # 报错,实例不能访问私有属性 # 输出:
# 1
# 2
# 2
# Traceback (most recent call last):
# File "test.py", line 16, in <module>
# print (counter.__secretCount) # 报错,实例不能访问私有变量
# AttributeError: 'JustCounter' object has no attribute '__secretCount'

类的方法

在类的内部,

  • 使用 def 关键字来定义一个方法
  • 类方法必须包含参数 self,且为第一个参数

    (self 的名字并不是规定死的,也可以使用 this,但是最好还是按照约定是用 self)
  • self 代表的是类的实例
#!/usr/bin/python3

#类定义
class people:
name = '' # 定义基本属性
age = 0
__weight = 0 # 定义私有属性, 私有属性在类外部无法直接进行访问
def __init__(self,n,a,w): # 定义构造方法
self.name = n
self.age = a
self.__weight = w
def speak(self):
print("%s 说: 我 %d 岁。" %(self.name,self.age)) # 实例化类
p = people('runoob',10,30)
p.speak() # 输出
# runoob 说: 我 10 岁。

类的私有方法

__private_method

  • 两个下划线开头,声明该方法为私有方法,
  • 只能在类的内部调用 ,不能在类的外部调用。

类的私有方法实例:

实例(Python 3.0+)
#!/usr/bin/python3 class Site:
def __init__(self, name, url):
self.name = name # public
self.__url = url # private def who(self):
print('name : ', self.name)
print('url : ', self.__url) def __foo(self): # 私有方法
print('这是私有方法') def foo(self): # 公共方法
print('这是公共方法')
self.__foo() x = Site('菜鸟教程', 'www.runoob.com')
x.who() # 正常输出
x.foo() # 正常输出
x.__foo() # 报错

类的内置方法

__init__        : 构造函数,在生成对象时调用
__del__ : 析构函数,释放对象时使用
__repr__ : 打印,转换
__setitem__ : 按照索引赋值
__getitem__ : 按照索引获取值
__len__ : 获得长度
__cmp__ : 比较运算
__call__ : 函数调用
__add__ : 加运算
__sub__ : 减运算
__mul__ : 乘运算
__truediv__ : 除运算
__mod__ : 求余运算
__pow__ : 乘方
__new__ | 生成实例所需属性 —— 创建实例时
__class__ | 实例所在的类 —— 实例.__class__
__name__ | 类名
__str__ | 实例字符串表示,可读性 —— print(类实例),如没实现,使用repr结果
__repr__ | 实例字符串表示,准确性 —— 类实例 回车 或者 print(repr(类实例))
__dict__ | 实例自定义属性 —— vars(实例.__dict__)
__doc__ | 类的文档字符串,子类不继承 —— help(类或实例)
__module__ | 类定义所在的模块
__bases__ | 类的所有父类构成元素(包含了一个由所有父类组成的元组)
__getattribute__ | 属性访问拦截器 —— 访问实例属性时
__delattr__(s,name) | 删除name属性 —— 调用时
__gt__(self,other) | 判断self对象是否大于other对 —— 调用时
__setattr__(s,name,value)| 设置name属性 —— 调用时
__gt__(self,other) | 判断self对象是否大于other对象 —— 调用时
__lt__(slef,other) | 判断self对象是否小于other对象 —— 调用时
__ge__(slef,other) | 判断self对象是否大于或者等于other对象 —— 调用时
__le__(slef,other) | 判断self对象是否小于或者等于other对象 —— 调用时
__eq__(slef,other) | 判断self对象是否等于other对象 —— 调用时
__call__(self,\*args) | 把实例对象作为函数调用 —— 调用时

运算符重载(重写内置方法)

Python同样支持运算符重载,我们可以对类的专有方法进行重载。

#!/usr/bin/python3

class Vector:
def __init__(self, a, b):
self.a = a
self.b = b def __str__(self):
return 'Vector (%d, %d)' % (self.a, self.b) def __add__(self,other):
return Vector(self.a + other.a, self.b + other.b) v1 = Vector(2,10)
v2 = Vector(5,-2)
print (v1 + v2) # 输出:
# Vector(7,8)

类对象

类对象支持两种操作:

1. 属性引用

属性引用使用和 Python 中所有的属性引用一样的标准语法:obj.name

实际上,创建一个类之后,可以(不用实例化)通过类名访问其属性。

2. 实例化。

类实例化后,可以使用其属性和方法

类对象创建后,类命名空间中所有的命名都是有效属性名。所以如果类定义是这样:

实例(Python 3.0+)
#!/usr/bin/python3 class MyClass:
"""一个简单的类实例"""
i = 12345
def f(self):
return 'hello world' # 实例化类
x = MyClass() # 访问类的属性和方法
print("MyClass 类的属性 i 为:", x.i)
print("MyClass 类的方法 f 输出为:", x.f()) # 以上创建了一个新的类实例并将该对象赋给局部变量 x,x 为空的对象。 # 输出:
# MyClass 类的属性 i 为: 12345
# MyClass 类的方法 f 输出为: hello world
  • 类有一个名为 __init__() 的特殊方法(构造方法),该方法 在类实例化时会自动调用

  • 类的方法与普通的函数只有一个特别的区别——它们必须有一个额外的第一个参数名称, 按照惯例它的名称是 self。

    self 代表 类的实例,而非类

class Test:
def prt(self):
print(self)
print(self.__class__) t = Test()
t.prt() # 输出:
# <__main__.Test instance at 0x100771878>
# __main__.Test

从执行结果可以很明显的看出,self 代表的是类的实例,代表当前对象的地址,而 self.class 则指向类。

--------------------------------

继承

普通继承

class DerivedClassName(BaseClassName1):
<statement-1>
...
<statement-N>

注意小括号中基类的顺序

若是基类中有相同的方法名,而在子类使用时未指定,
则 python 从左至右搜索 即方法在子类中未找到时,从左到右查找基类中是否包含方法。

BaseClassName(示例中的基类名)必须与派生类定义在一个作用域内。

除了类,还可以用表达式,基类定义在另一个模块中时这一点非常有用:

class DerivedClassName(modname.BaseClassName):
#!/usr/bin/python3

# 父类 (基类)
class people:
name = '' # 定义基本属性
age = 0
__weight = 0 # 定义私有属性,私有属性在类外部无法直接进行访问
def __init__(self,n,a,w): # 定义构造方法
self.name = n
self.age = a
self.__weight = w
def speak(self):
print("%s 说: 我 %d 岁。" %(self.name,self.age)) # 单继承示例
class student(people):
grade = ''
def __init__(self, n, a, w, g):
people.__init__(self, n, a, w) # 调用父类的构用函数
self.grade = g def speak(self): # 【覆写】父类的方法
print("%s 说: 我 %d 岁了,我在读 %d 年级"%(self.name,self.age,self.grade)) s = student('ken',10,60,3)
s.speak() # 输出
# ken 说: 我 10 岁了,我在读 3 年级

多继承

class DerivedClassName(Base1, Base2, Base3):
<statement-1>
...
<statement-N>

注意小括号中继承父类的顺序

若是父类中有相同的方法名,而在子类使用时未指定,
python从左至右搜索 即方法在子类中未找到时,从左到右查找 父类中是否包含方法。

#!/usr/bin/python3

# 父类
class people:
name = ''
age = 0
__weight = 0
def __init__(self,n,a,w):
self.name = n
self.age = a
self.__weight = w
def speak(self):
print("%s 说: 我 %d 岁。" %(self.name,self.age)) # 单继承示例
class student(people):
grade = ''
def __init__(self,n,a,w,g):
people.__init__(self,n,a,w) # 调用父类的构函
self.grade = g def speak(self): # 覆写父类的方法
print("%s 说: 我 %d 岁了,我在读 %d 年级"%(self.name,self.age,self.grade)) #另一个类
class speaker():
topic = ''
name = ''
def __init__(self,n,t):
self.name = n
self.topic = t
def speak(self):
print("我叫 %s,我是一个演说家,我演讲的主题是 %s"%(self.name,self.topic)) # 多重继承
class sample(speaker, student):
a =''
def __init__(self,n,a,w,g,t):
student.__init__(self,n,a,w,g)
speaker.__init__(self,n,t) test = sample("Tim",25,80,4,"Python") # 方法名同,调用的是在括号中排【前地父类】的方法
test.speak() # 输出:
# 我叫 Tim,我是一个演说家,我演讲的主题是 Python

方法重写(覆写)

如果你的父类方法的功能不能满足你的需求,你可以在子类重写你父类的方法,

#!/usr/bin/python3

class Parent:               # 父类
def myMethod(self):
print ('调用父类方法') class Child(Parent): # 子类
def myMethod(self):
print ('调用子类方法')

super() 函数

调用父类(超类)的一个方法。

c = Child()                 # 子类实例

c.myMethod()                # 子类调用重写方法
super(Child,c).myMethod() # !用子类对象调用父类已被覆盖的方法 # 输出:
# 调用子类方法
# 调用父类方法

更多文档:

Python 子类继承父类构造函数说明


python class 巩固的更多相关文章

  1. Python中的多进程与多线程(一)

    一.背景 最近在Azkaban的测试工作中,需要在测试环境下模拟线上的调度场景进行稳定性测试.故而重操python旧业,通过python编写脚本来构造类似线上的调度场景.在脚本编写过程中,碰到这样一个 ...

  2. Python高手之路【六】python基础之字符串格式化

    Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...

  3. Python 小而美的函数

    python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况   any any(iterable) ...

  4. JavaScript之父Brendan Eich,Clojure 创建者Rich Hickey,Python创建者Van Rossum等编程大牛对程序员的职业建议

    软件开发是现时很火的职业.据美国劳动局发布的一项统计数据显示,从2014年至2024年,美国就业市场对开发人员的需求量将增长17%,而这个增长率比起所有职业的平均需求量高出了7%.很多人年轻人会选择编 ...

  5. 可爱的豆子——使用Beans思想让Python代码更易维护

    title: 可爱的豆子--使用Beans思想让Python代码更易维护 toc: false comments: true date: 2016-06-19 21:43:33 tags: [Pyth ...

  6. 使用Python保存屏幕截图(不使用PIL)

    起因 在极客学院讲授<使用Python编写远程控制程序>的课程中,涉及到查看被控制电脑屏幕截图的功能. 如果使用PIL,这个需求只需要三行代码: from PIL import Image ...

  7. Python编码记录

    字节流和字符串 当使用Python定义一个字符串时,实际会存储一个字节串: "abc"--[97][98][99] python2.x默认会把所有的字符串当做ASCII码来对待,但 ...

  8. Apache执行Python脚本

    由于经常需要到服务器上执行些命令,有些命令懒得敲,就准备写点脚本直接浏览器调用就好了,比如这样: 因为线上有现成的Apache,就直接放它里面了,当然访问安全要设置,我似乎别的随笔里写了安全问题,这里 ...

  9. python开发编译器

    引言 最近刚刚用python写完了一个解析protobuf文件的简单编译器,深感ply实现词法分析和语法分析的简洁方便.乘着余热未过,头脑清醒,记下一点总结和心得,方便各位pythoner参考使用. ...

  10. 关于解决python线上问题的几种有效技术

    工作后好久没上博客园了,虽然不是很忙,但也没学生时代闲了.今天上博客园,发现好多的文章都是年终总结,想想是不是自己也应该总结下,不过现在还没想好,等想好了再写吧.今天写写自己在工作后用到的技术干货,争 ...

随机推荐

  1. 前端三部曲之Html -- 1(html的基本结构和常见的meta标签的作用)

    一个H5页面的基本结构是什么 我么在编辑器中输入html:5可以得到 <!DOCTYPE html> <!-- 声明文档类型 --> <html lang="e ...

  2. try catch finally的执行顺序学习

    try catch finally的执行顺序学习   首先执行try,如果有异常执行catch,无论如何都会执行finally,当有return以后,函数就会把这个数据存储在某个位置,然后告诉主函数, ...

  3. vue中修改swiper样式

    问题 vue单文件组件中无法修改swiper样式. 解决 1,单文件组件中:新增一个style 不加scoped 让它最终成为全局样式.只在其中操作swiper的样式. <style lang= ...

  4. MySQL索引原理与慢查询

    =========索引原理与慢查询======= 阅读目录 -     一.介绍 -     二.索引的原理 -     三.索引的数据结构 -     四.聚集索引与辅助索引 -     五.MyS ...

  5. python进阶03 继承

    python进阶03 继承 一.继承 课堂练习:假设你正在参与一个魔幻类角色游戏的开发,公司需要腻味这个游戏设计两个角色的类: a.剑士 属性:1.角色名:2.角色等级:3.生命值:4.攻击力 行为: ...

  6. Codeforces Round #529 -C- Powers Of Two(二进制拆分)

    A positive integer xx is called a power of two if it can be represented as x=2yx=2y, where yy is a n ...

  7. NET Core 2.0 微服务跨平台实践

    NET Core 2.0 微服务跨平台实践 相关博文: Ubuntu 简单安装 Docker Mac OS.Ubuntu 安装及使用 Consul Consul 服务注册与服务发现 Fabio 安装和 ...

  8. High waits on control file sequential read

    High waits on control file sequential read (文档 ID 2277867.1) In case we run into an issue where cont ...

  9. HDU 5883 F - The Best Path 欧拉通路 & 欧拉回路

    给定一个图,要求选一个点作为起点,然后经过每条边一次,然后把访问过的点异或起来(访问一次就异或一次),然后求最大值. 首先为什么会有最大值这样的分类?就是因为你开始点选择不同,欧拉回路的结果不同,因为 ...

  10. Java定时器Timer,TimerTask每隔一段时间随机生成数字

    1:java.util.Timer类是一种工具,线程用其安排以后在后台线程中执行的任务.可安排任务执行一次,或者定期重复执行. 2:TimerTask类是由 Timer 安排为一次执行或重复执行的任务 ...