Python面向对象基础
1.编程思想
面向过程编程、函数式编程、面向对象编程
# 编程实现功能:1*2*3*..*10
# 面向过程编程:
s = 1
for x in range(1, 11):
s *= x
print(s)
# 函数式编程:
from math import factorial
print(factorial(10))
# 面向对象编程
class Math:
@staticmethod
def factorial(num: int):
s = 1
for x in range(1, num+1):
s *= x
return s
print(Math.factorial(10))
2.类和对象
-
什么是类、什么是对象
类:拥有相同功能相同属性的对象的集合 (抽象的概念)
对象:对象是类的实例(具体的事物)
从生活的角度理解类和对象:
人是类,小红就是对象、小明是另外一个对象
杯子是类,我桌上这个杯子就是对象
-
创建类和创建对象
1)创建类 - 就是用代码描述清楚这个类是拥有哪些相同功能(函数)和哪些相同属性(变量)的对象的集合
语法:
class 类名:
类的说明文档
类的内容
说明:
class - 关键字;固定写法
类名 - 程序员自己命名;
要求:标识符、不是关键字
规范:见名知义;驼峰式命名,并且第一个字母大写;不使用系统的函数名、类名、模块名
: - 固定写法
类的说明文档 - 多行注释
类的内容 - 包含属性和方法
属性:类属性(类的字段)、对象属性
方法:对象方法、类方法、静态方法
注:方法是定义在类中的函数
- 创建对象
语法:
类名()
# 创建类 class Person: """类的说明文档""" # 属性 # 方法 pass # 创建对象 p1 = Person() print(p1) p2 = Person() print(p2)
3.方法
-
方法 - 定义在类中的函数
1)对象方法
a.怎么定义:直接定义在类中
b.怎么调用:对象.
c.特点:有个默认参数self,self不用传参,谁调用self就指向谁
d.什么时候用:如果实现函数的功能需要用到对象属性,就将定义成对象方法
2)类方方法
a.怎么定义:定义函数前加装饰 @classmethod
b.怎么调用:类.
c.特点:有个默认参数cls,调用时候不用传参,系统自动将当前类传给cls
d.什么时候用:在不需要对象属性的前提下,需要类
3)静态方法
a.怎么定义:定义函数前加装饰器 @staticmethod
b.怎么调用:类.
c.特点:没有默认参数
d.什么时候用:在不需要对象属性的前提下,也不需要类
class A: def func1(self): print('对象方法') print(A) @classmethod def func2(cls): print(f'cls:{cls}') print('类方法') b = cls() print(f'b:{b}') @staticmethod def func3(): print('静态方法') a = A() # 对象方法 a.func1() # <class '__main__.A'> print(f'A:{A}') # A:<class '__main__.A'> A.func2() ''' cls:<class '__main__.A'> 类方法 b:<__main__.A object at 0x000001B5B7098FD0> ''' A.func3() #静态方法
- __init__方法 - 初始化方法
1)构造方法: 函数名和类名相同,用来创建对象的函数就是构造函数(构造方法)
python的构造函数,需要程序员自己写,创建类的时候系统会自动创建这个类的构造函数
2)初始化方法:
a. 当通过类创建对象的时候系统会自动调用__init__方法
b. 在调用调用构造函数创建对象的时候,需不需要参数需要几个参数看对应的__init__除了self以外有
没有额外的参数,有几个额外的参数。
c. 程序员在类中添加__init_方法的时候只需要保证方法名是__init__有默认参数self就可以。
形参和函数体可以根据情况随便添加
补充:前后都有两个下划线的方法又叫魔法方法,这类方法不需要程序员去调用,在特定情况下会被自动调用
class Dog:
def __init__(self, x=9):
print('初始化方法')
p1 = Dog(10) #初始化方法
p2 = Dog(x=20) # 初始化方法
p3 = Dog() # 初始化方法
4.属性
- 属性 - 定义在类中的变量
- 类属性
a.怎么定义: 直接定义类中的变量
b.怎么使用: 通过 ‘类.’ 的方式来使用
c.什么时候用: 属性值不会因为对象不同而不一样
- 对象属性
a.怎么定义:以 ‘self.属性名 = 值’ 的形式定义在__init__方法中
b.怎么使用:以 '对象.'的方式来使用
c.什么时候用: 属性值会因为对象不同而不一样的时候就使用对象属性
class Circle: # a 是类属性 a = 10 # pi 是类属性 pi = 3.1415926 # radius是对象属性 def __init__(self): self.radius = 1 # 使用类属性 print(Circle.a) c1 = Circle() # 使用对象属性 print(c1.radius)
- 对象属性的初始值
class Person: def __init__(self, name, gender='男'): self.name = name self.gender = gender self.age = 0 p1 = Person('小明') p2 = Person('张三') p3 = Person('小花', '女') print(p1.name, p1.gender) print(p2.name, p2.gender) print(p3.name, p3.gender)
- 在对象方法中对象属性的使用
class Circle: pi = 3.1415926 def __init__(self, radius): self.radius = radius def area(self): # 如果在实现对象方法的功能的时候需要用到对象属性,由self来提供这个对象属性 # return 圆周率 x 圆半径的平方 return Circle.pi * self.radius ** 2 c1 = Circle(2) c2 = Circle(4) print(c1.area()) print(c2.area())
练习
-
定义一个狗类和一个人类:
狗拥有属性:姓名、性别和品种 拥有方法:叫唤
人类拥有属性:姓名、年龄、狗 拥有方法:遛狗
class Dog: def __init__(self, name, gender, breed): self.name = name self.gender = gender self.breed = breed def func1(self): return (f'{self.name}在叫唤') class Person: def __init__(self, name, age): self.name = name self.age = age self.dog = None def func2(self): if self.dog: return (f'{self.name}在遛{self.dog.name}') else: return ('没有狗,自己散步') p1 = Person('小米', '11') p1.dog =Dog('七七', '公', '柯基') print(p1.func2())
- 定义一个矩形类,拥有属性:长、宽 拥有方法:求周长、求面积
class rectangle: def __init__(self,length, width): self.lenget =length self.width =width def perimeter(self): return (self.width +self.lenget)*2 def ares(self): return self.width *self.lenget p1 =rectangle(5,6) print(p1.ares()) print(p1.perimeter())
- 定义一个二维点类,拥有属性:x坐标、y坐标 拥有方法:求当前点到另外一个点的距离
class TwoDimension: def __init__(self, x, y): self.x = x self.y = y def distance(self, other): return ((self.x - other.x) ** 2 + (self.y - other.y) ** 2) ** 0.5 p2 = TwoDimension(3, 4) p3 = TwoDimension(0, 0) print(p2.distance(p3))
- 定义一个圆类,拥有属性:半径、圆心 拥有方法:求圆的周长和面积、判断当前圆和另一个圆是否外切
class Circle: pi = 3.14 def __init__(self, radius,center=TwoDimension(0,0)): self.radius = radius self.center =center def ares(self): return Circle.pi * self.radius ** 2 def perimeter(self): return 2 * Circle.pi * self.radius def excircle(self,other): return self.radius+other.radius ==self.center.distance(other.center) p1 =Circle(8,center=TwoDimension(3, 4)) p2 =Circle(5,center=TwoDimension(3, 4)) print(p1.excircle(p2))
- 定义一个线段类,拥有属性:起点和终点, 拥有方法:获取线段的长度
class Segment: def __init__(self, start=TwoDimension(0,0), end=TwoDimension(0,0)): self.start = start self.end = end def length(self): return self.start.distance(self.end) p1 =Segment(start=TwoDimension(0,0),end=TwoDimension(9,9)) print(p1.length())