Python学习笔记

https://www.yuque.com/docs/share/0b3bac66-aa8c-4143-aaa9-0955f609dcb9?# 《Python学习笔记2》https://www.yuque.com/docs/share/0b3bac66-aa8c-4143-aaa9-0955f609dcb9?#%20%E3%80%8APython%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B02%E3%80%8B里面链接是我假期的Python学习笔记,想了解的伙伴可以点进去查看,下面的知识点是其中的一小部分,编程思想

8.1两大编程思想

面向过程

面向对象

区别

事物比较简单,可以用线性 的思维去解决

事物比较复杂,使用简单的线性思维无法解决

共同点

面向过程和面向对象都是解决实际问题的一种思维方式

两者相辅相成,并不是对立的

解决复杂问题,通过面向对象方式便于我们从宏观上把握事物之间复杂的关系,方便我们分析

整个系统,具体到微观操作,仍然使用面向过程方式来处理

8.2类与对象的创建

类别,分门别类,物以类聚,人类,鸟类,动物类,植物类....

类是多个类似事物组成的群体的统称。能够帮助我们快速理解和判断事物

1.数据类型

不同的数据类型属于不同的类

使用内置函数查看数据类型

2.对象

100,99,520都是int类之下包含的相似的不同个例,这个个例专业数语称之为实例或对象

1.类的创建

  1. 创建类的语法

lass Student:

pass

  1. 类的组成

类属性 实例方法 静态方法 类方法

class Student:
passprint(type(Student),id(Student))print(Student)

Student为类的名称(类名)由一个或多个单词组成,每个单词的首字母大写,其余小写

直接写在类里的变量,称之为类属性

实例方法

def eat(self):
print("学生在吃饭")

静态方法

@staticmethoddef method():
print("staticmethod进行修饰为静态方法,不能使用self")

在类之外定义的称之为函数,在类之内定义的称之为方法

静态方法进行修饰,不能使用self

类方法

@classmethoddef cm(cls):
print("classmethod进行修饰为类方法,使用cls")

Init初始化方法

def __init__(self,name,age):
self.name=name
self.age=age

Self.name称之为实体属性,进行了一个赋值操作,将局部变量的name的值赋给实体变量

2.对象的创建

对象的创建又称为类的实例化

语法:

实例名=类名()

举例:Stu=Student()

意义:有了实例,就可以调用类中的内容

class Student:
native_pace='吉林'
def __init__(self,name,age):
self.name=name
self.age=age
stu1=Student("张三",20)print("实例对象",id(stu1))print(type(stu1))print(stu1)print("--------")print("类对象",id(Student))print(type(Student))print(Student)

8.3动态绑定属性和方法

Python是动态语言,在创建对象之后,可以动态地绑定属性和方法

一个Student类可以创建多个Student类的实例对象,每个实体对象的属性值不同

class Student:
native_pace='吉林'
def __init__(self,name,age):
self.name= name
self.age=age
def eat(self):
print(self.name+"在吃饭")
stu1=Student("张三",20)
stu2=Student("李四",30)print(id(stu1))print(id(stu2))print("只为为stu2动态绑定性别")
stu2.gender="女"print(stu2.name,stu2.age,stu2.gender)print(stu1.name,stu1.age)
stu1.eat()
stu2.eat()def show():
print("定义在类之外,称函数")
stu1.show=showprint("绑定在对象之后就成为show方法")
stu1.show()

8.4类属性、类方法、静态方法

类属性:类中方法外的变量称之为类属性,被该类的所有对象所共享

类方法:使用@classmethod修饰的方法,使用类名直接访问的方法

静态方法:使用@staticmethod修饰的主法,使用类名直接访问的方法

Print(Student.native_place) #访问类属性

Student.cm() #调用类方法

Student.sm() #调用静态方法

class Student:
native_pace='吉林'
def __init__(self, name, age):
self.name = name
self.age = age
stu1=Student("张三",20)
stu2=Student("李四",30)print(stu1.native_pace)print(stu2.native_pace)
Student.native_pace="天津"print(stu1.native_pace)print(stu2.native_pace)

class Student:
native_pace='吉林'
@classmethod
def cm(cls):
print("classmethod进行修饰为类方法,使用cls")
@staticmethod
def method():
print("staticmethod进行修饰为静态方法,不能使用self")
Student.cm()
Student.method()

8.5面向对象的三大属性

8.5.1封装

封装:提高程序的安全性

将数据(属性)和行为(方法)包装到类对象中。在方法内部对属性进行操作,在类对象的外部调用方法。这样,无需关心方法内部的具体实现细节,从而隔离了复杂度

在python中没有专门的修饰符用于属性的私有,如果改属性不希望在类对象外部被访问,前面使用两个“_”

继承:提高代码的复用性

多态:提高代码的可扩展性和可维护性

class Car:
def __init__(self,brand):
self.brand=brand
def start(self):
print("汽车已启动")
car=Car("宝马X5")
car.start()print(car.brand)

年龄不希望在类的外部被调用,所有使用两个“_”

在类的外部可以通过_Student__age进行访问

class Student:
def __init__(self,name,age):
self.name=name
self.__age=age
def show(self):
print(self.name,self.__age)
stu=Student("张三",20)
stu.show()print(stu.name)#print(dir())
#print(stu._Student__age)

8.5.2继承

语法格式:

class 字典类名(父级1,父级2):

pass

如果一个类都没有继承任何类,则默认继承object

Python支持多继承

定义子集时,必须在其构造函数中调用父类的构造函数

class Person(object):
def __init__(self,name,age):
self.name=name
self.age=age
def info(self):
print(self.name,self.age)class Student(Person):
def __init__(self,name,age,stu_no):
super().__init__(name,age)
self.stu_no=stu_noclass Teacher(Person):
def __init__(self,name,age,teachofyear):
super().__init__(name,age)
self.teachofyear=teachofyear
stu=Student("张三",20,"1001")
teacher=Teacher("李四",34,10)
stu.info()
teacher.info()

多继承

class A(object):
pass
class B(object):
pass
class C(A,B):
pass

8.5.3方法重写

如果子类对继承自父类的某个属性或方法不满意,可以在子类中对其(方法体)进行重新编写

子类重写后的方法中可以通过super().XXX()调用父类中被重写的方法

class Person(object):
def __init__(self,name,age):
self.name=name
self.age=age
def info(self):
print(self.name,self.age)class Student(Person): #继承
def __init__(self,name,age,stu_no):
super().__init__(name,age)
self.stu_no=stu_no
def info(self):
super().info()
print("学号",self.stu_no)class Teacher(Person):
def __init__(self,name,age,teachofyear):
super().__init__(name,age)
self.teachofyear=teachofyear
def info(self):
super().info()
print("教龄:",self.teachofyear)
stu=Student("张三",20,"1001")
teacher=Teacher("李四",34,10)
stu.info()print("-------")
teacher.info()

8.5.4 object类

(1)object类是所有类的父亲,因此所有类都有object类的属性和方法

(2)内置函数dir()可以查看指定对象所有属性

(3)Object有一个__str__()方法,用于返回一个对于“对象的描述”,对应于内置函数str()

经常用于print()方法,帮我们查看对象的信息,所以我们经常会对__str__()进行重写

class Student:
def __init__(self,name,age):
self.name=name
self.age=age
def __str__(self):
return "我的名字是{0},今年{1}岁".format(self.name,self.age)
stu=Student("张三",20)print(dir(stu))print(stu)print(type(stu))

8.5.5多态

简单地说,多态就是“具有多种形态”,它指的是:即便不知道一个变量所引用的对象到底是什么类型,仍然可以通过这个变量调用方法,在运行过程中根据变量所引用对象的类型,动态决定调用哪个对象中的方法

class Animal:
def eat(self):
print("动物会吃")class Dog(Animal):
def eat(self):
print("狗吃骨头")class Cat(Animal):
def eat(self):
print("猫吃鱼")class Peason():
def eat(self):
print("人吃五谷杂粮")#定义一个函数def fun(obj):
obj.eat()#开始调用函数fun(Cat())
fun(Dog())
fun(Animal())print("----------")
fun(Peason())

附:静态语言和动态语言

静态语言和动态语言关于多态的区别

静态语言实现多态的三个必要条件

继承,方法重写,父类引用指向子类对象

8.5.6特殊方法和特殊属性

名称

描述

特殊属性

__dict__

获得类对象或实例对象所绑定的所有属性和方法的字典

特殊方法

__len__()

通过重写__len__()方法,让内置函数len()的参数可以 是自定义类型

__add__()

通过重写__add__()方法,可使自定义对象具有“+”功能

__new__()

用于创建对象

__init__()

对创建的对象进行初始化

print(dir(object))class A:
pass
class B:
pass
class C(B,A):
def __init__(self,name,age):
self.name=name
self.age=ageclass D(A):
passx=C("jack",20)#x是c类型的实例类型print("实例对象的属性字典",x.__dict__) #print("类对象的属性内容",C.__dict__)print("---------------—-----")print("输出了对象所属的类",x.__class__)print("C类父类类型的元素",C.__bases__)print("定义时C类型最近的父级元素",C.__base__)print("类的层次结构",C.__mro__)print("子类列表",A.__subclasses__())

特殊方法__add__()

a=20b=100c=a+b
d=a.__add__(b)print(c)print(d)
class Student:
def __init__(self,name):
self.name=name
def __add__(self, other):
return self.name+other.name
stu1=Student("张三")
stu2=Student("李四")
s=stu1+stu2print("两个对象相加方法一",s)
s=stu1.__add__(stu2)print("两个对象相加方法二",s)

特殊方法__len__()

class Student:
def __init__(self,name):
self.name=name
def __len__(self):
return len(self.name)
stu1=Student("Python")print("stu1()中Python的长度",len(stu1))
lst=[11,22,33,44]print("列表的长度",len(lst))print("len是内置函数len")print("列表的长度",lst.__len__())

特殊方法__new__()特殊方法__init__()

class Person(object):
def __init__(self,name,age):
self.name=name
self.age=age
def __new__(cls, *args, **kwargs):
print("__new__被调用执行了,cls的id值为:{0}".format(id(cls)))
obj=super().__new__(cls)
print("创建的对象的id为{0}".format(id(obj)))
return obj
def __init__(self,name,age):
print("__init__被调用了,self的id值为:{0}".format(id(self)))
self.name=name
self.age=ageprint("object这个类对象的id值为:{0}".format(id(object)))print("Person这个类对象的id值为:{0}".format(id(Person)))
p1=Person("张三",20)print("p1这个Person类的实例对象的id:".format(id(p1)))

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

K.A.L

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值