# 面向对象
# !/usr/bin/python3
# 类的专有方法:
# __init__ : 构造函数,在生成对象时调用
# __del__ : 析构函数,释放对象时使用
# __repr__ : 打印,转换
# __setitem__ : 按照索引赋值
# __getitem__: 按照索引获取值
# __len__: 获得长度
# __cmp__: 比较运算
# __call__: 函数调用
# __add__: 加运算
# __sub__: 减运算
# __mul__: 乘运算
# __truediv__: 除运算
# __mod__: 求余运算
# __pow__: 乘方
class MyClass:
"""一个简单的类实例"""
# 定义基本属性
i = 12345
#定义私有属性,私有属性在类外部无法直接进行访问
__weight = 0
# self代表类的实例,而非类
# 类的方法与普通的函数只有一个特别的区别——它们必须有一个额外的第一个参数名称, 按照惯例它的名称是 self。
def f(self):
return 'hello world'
def prt(self):
# self 代表的是类的实例,代表当前对象的地址,而 self.class 则指向类
print(self)
print(self.__class__)
# self 不是 python 关键字,我们把他换成 runoob 也是可以正常执行的:
def prt2(runoob):
print(runoob)
print(runoob.__class__)
def __init__(self, realpart, imagpart):
self.a = realpart
self.b = imagpart
# 实例化类
x = MyClass(3.0, -4.5)
# 访问类的属性和方法
print("MyClass 类的属性 i 为:", x.i)
print("MyClass 类的方法 f 输出为:", x.f())
print(x.a, x.b) # 输出结果:3.0 -4.5
x.prt()
x.prt2()
# 继承
# 类定义
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)
# 单继承
s = student('ken', 10, 60, 3)
s.speak()
# 多继承
test = sample("Tim",25,80,4,"Python")
test.speak() #方法名同,默认调用的是在括号中排前地父类的方法
# 重写
class Parent: # 定义父类
def myMethod(self):
print('调用父类方法')
class Child(Parent): # 定义子类
def myMethod(self):
print('调用子类方法')
c = Child() # 子类实例
c.myMethod() # 子类调用重写方法
super(Child, c).myMethod() # 用子类对象调用父类已被覆盖的方法
#私有方法
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() # 报错
# 类的运算符重载
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)
python 面向对象 类的方法
于 2019-12-19 15:37:34 首次发布
本文深入讲解了Python中的面向对象编程,包括类的定义、对象的创建、私有属性和方法的使用,以及类的继承和多态性。通过具体实例演示了如何在Python中实现类的运算符重载。
488

被折叠的 条评论
为什么被折叠?



