python 面向对象学习

面向对象

1、面向对象一些基本的定义

  • 类(class):用来描述具有相同的属性和方法的对象的集合。它定义了该集合中每个对象所共有的属性和方法。对象是类的实例。
  • 方法:类中定义的函数。
  • 类变量:类变量在整个实例化的对象中是公用的。类变量定义在类中且在函数体之外。类变量通常不作为实例变量使用。
  • 数据成员:类变量或者实例变量用于处理类及其实例对象的相关的数据。
  • 方法重写:如果从父类继承的方法不能满足子类的需求,可以对其进行改写,这个过程叫方法的覆盖(override),也称为方法的重写。
  • 局部变量:定义在方法中的变量,只作用于当前实例的类。
  • 实例变量:在类的声明中,属性是用变量来表示的。这种变量就称为实例变量,是在类声明的内部但是在类的其他成员方法之外声明的。
  • 继承:即一个派生类(derived class)继承基类(base class)的字段和方法。继承也允许把一个派生类的对象作为一个基类对象对待。例如,有这样一个设计:一个Dog类型的对象派生自Animal类,这是模拟"是一个(is-a)"关系(例图,Dog是一个Animal)。
  • 实例化:创建一个类的实例,类的具体对象。
  • 对象:通过类定义的数据结构实例。对象包括两个数据成员(类变量和实例变量)和方法。

接下来用一个例子来说明这些定义:

class Student:              #定义一个名为 Student 的类
    age=20                   #定义 Student 类的属性,公有变量
    __name=''                #私有变量
    def a(self):             #定义 Student 类的方法,self 代表类的实例
        return self.age
class Student1(Student):     #类的继承
    def show(self):
        print(self.age+1)
p=Student1()                #创建了一个类的实例
print(p.a())
p.show()

结果为:

 

 类还有一些专有方法:

  • __init__ : 构造函数,在生成对象时调用
  • __del__ : 析构函数,释放对象时使用
  • __repr__ : 打印,转换
  • __setitem__ : 按照索引赋值
  • __getitem__: 按照索引获取值
  • __len__: 获得长度
  • __cmp__: 比较运算
  • __call__: 函数调用
  • __add__: 加运算
  • __sub__: 减运算
  • __mul__: 乘运算
  • __truediv__: 除运算
  • __mod__: 求余运算
  • __pow__: 乘方

 

类的三个要素:封装、继承、多态 。

封装 :根据 职责 将 属性 和 方法 封装 到一个抽象的 类 中。

继承 :实现代码的重用,相同的代码不需要重复的编写。

多态 :不同的对象调用相同的方法,产生不同的执行结果,增加代码的灵活度。

 

 

类class中以下划线开头的变量名特点:

 

1、单下划线"_":

 

在Python中,通过单下划线"“来实现模块级别的私有化,变量除外。一般约定以单下划线”"开头的函数为模块私有的,也就是说"from moduleName import * “将不会引入以单下划线”_"开头的函数。
2、双下划线"__":
对于Python中的类属性,可以通过双下划线"__“来实现一定程度的私有化,因为双下划线开头的属性在运行时会被"混淆”。双下划线的另一个重要的目地是,避免子类对父类同名属性的冲突。
总结:
"__“和” _ __"的使用 更多的是一种规范/约定,并没有真正达到限制的目的:
“_”:以单下划线开头的表示的是protected类型的变量,即只能允许其本身与子类进行访问;同时表示弱内部变量标示,如,当使用"from moduleNmae import *"时,不会将以一个下划线开头的对象引入。
“__”:双下划线的表示的是私有类型的变量。只能是允许这个类本身进行访问了,连子类也不可以,这类属性在运行时属性名会加上单下划线和类名。
 
 

设计一个三维向量类,并实现向量的加法、减法以及向量与标量的乘法和除法代码如下:

 

class Vecter3:
    def __init__(self, x=0, y=0, z=0):
        self.X = x
        self.Y = y
        self.Z = z
    def __add__(self, n):
        r = Vecter3()
        r.X = self.X + n.X
        r.Y = self.Y + n.Y
        r.Z = self.Z + n.Z
        return r
    def __sub__(self, n):     
        r = Vecter3()
        r.X = self.X - n.X
        r.Y = self.Y - n.Y
        r.Z = self.Z - n.Z
        return r
    def __mul__(self, n):
        r = Vecter3()
        r.X = self.X * n
        r.Y = self.Y * n
        r.Z = self.Z * n
        return r
    def __truediv__(self, n):
        r = Vecter3()
        r.X = self.X / n
        r.Y = self.Y / n
        r.Z = self.Z / n
        return r
    def __floordiv__(self, n):
        r = Vecter3()
        r.X = self.X // n
        r.Y = self.Y // n
        r.Z = self.Z // n
        return r
    def show(self):                     #输出运算后的三维坐标
        print((self.X,self.Y,self.Z))
x1,y1,z1=map(eval,input("请输入第一个三维向量的坐标:").split(','))
x2,y2,z2=map(eval,input("请输入第二个三维向量的坐标:").split(','))
v1=Vecter3(x1,y1,z1)
v2=Vecter3(x2,y2,z2)
v3 = v1+v2
v3.show()                          
v4=v1-v2
v4.show()                          
n=eval(input("请输入标量n:"))
v5=v1*n
v5.show()
v6=v1/n
v6.show()

运行代码后,结果为:

 

 

字符串匹配(输入一段英文,输出只有三个字符的单词):

 

import re
a=[]
words=input("Input the words:")
l=re.split('[\. ]+',words)  
i=0   
for i in l:
    if len(i)==3: 
        if i not in a:
            a.append(i)
    else:
        continue
for k in range(0,len(a)):
    print(a[k],end=' ')

 

结果为:

 

posted on 2019-04-17 10:21  芷若丶初见  阅读(195)  评论(0编辑  收藏  举报