一. 封装

class Room:
def __init__(self, name, length, width):
self.__name = name
self.__length = length
self.__width = width
def get_name(self):
return self.__name
def set_name(self, newName):
if type(newName) is str and newName.isdigit() == False:
self.__name = newName
else:
print('不合法的姓名')
def area(self):
return self.__length * self.__width jin = Room('金老板的小窝', 5, 10)
print(jin.area())
jin.set_name('')
print(jin.get_name())
# 假设父类的私有属性,能被 子类 调用吗? 不能
class Foo:
__key = '' # _Foo__key class Son(Foo):
print(Foo.__key) # _Son__key
会用到私有的这个概念的场景
1. 隐藏起一个属性 不想让类的外部调用
2. 我想保护这个属性,不想让属性随意被改变
3. 我想保护这个属性,不被子类继承

二. property

 内置装饰器函数,只在面向对象中使用

from math import pi
class Circle:
def __init__(self, r):
self.r = r
@property
def perimeter(self):
return 2 * pi * self.r
@property
def area(self):
return pi * self.r**2
c1 = Circle(10)
print(c1.area) # 圆的面积
print(c1.perimeter) # 圆的周长

class Count_bmi:
def __init__(self, name, weight, height):
self.name = name
self.weight = weight
self.height = height
@property
def bmi(self):
return self.weight / (self.height**2)
kidd = Count_bmi('KID', 51, 1.68)
print(kidd.bmi)
kidd.bmi = 23 # 不能改 class Person:
def __init__(self, name):
self.__name = name
@property
def name(self):
return self.__name + 'SB'
@name.setter
def name(self, newName):
self.__name = newName
p = Person('qqq')
print(p.name)
p.name = 'ppp'
print(p.name)

class Goods:            # 定义一个超市物品
discount = 0.5 # 全场5折
def __init__(self, name, price):
self.name = name
self.__price = price
@property
def price(self):
return self.__price * Goods.discount apple = Goods('苹果',4)
print(apple.price)
# 属性:查看 修改 删除
# 刚才学了 查看 修改 ,接下来看看怎么删除(不常用)
class Person:
def __init__(self, name):
self.__name = name
@property
def name(self):
return self.__name
@name.deleter
def name(self):
print('执行了这个方法')
del self.__name
@name.setter
def name(self,newName):
self.__name = newName
p = Person('二哥')
print(p.name)
del p.name
print(p.name) # 在查看就会报错,因为已经删除

三. 类方法

class Goods:            # 定义一个超市物品
__discount = 0.5 # 全场5折
def __init__(self, name, price):
self.name = name
self.__price = price
@property
def price(self):
return self.__price * Goods.__discount
@classmethod # 把一个方法变声一个类中的方法,这个方法就直接可以被类调用,不需要依托任何对象
def change_discount(cls, newDiscount): # 修改折扣
cls.__discount = newDiscount
apple = Goods('苹果',4)
print(apple.price)
Goods.change_discount(0.8) # Goods.change_discount(Goods)
print(apple.price)
当这个方法的操作只涉及静态属性时,就应该使用calssmethod来装饰这个方法
class Login:
def __init__(self, name, password):
self.name = name
self.password = password
def login(self):
pass
@staticmethod
def get_usr_pwd(): # 静态方法
usr = input('用户名:')
pwd = input('密码:')
Login(usr,pwd)
Login.get_usr_pwd()
在完全面向对象的程序中
如果一个函数既和对象没有关系 也和类没有关系 那么就用staticmethod 将这个函数改变成一个静态方法 类方法 和 静态方法 都是类调用的
那么对象可以调用 类方法 和 静态方法 吗? 可以 一般情况下 推荐用类名调用
类方法 有一个默认参数 cls 代表这个类,可以改变这个名字,但不建议改变(与self代表对象似的)
静态方法 没有默认的参数 就像函数一样

四. 初识反射

name = 'alex'

class Teacher:
dic = {
'查看学生信息':'show_student',
'查看讲师信息':'show_teacher'
}
def show_student(self):
print('show_student')
def show_teacher(self):
print('show_teacher')
@classmethod
def func(self):
print('哈哈哈')
alex = Teacher()
for k in Teacher.dic:
print(k)
key = input('输入需求:')
# print(Teacher.dic[key])
if hasattr(alex,Teacher.dic[key]):
func = getattr(alex,Teacher.dic[key])
func() # # alex.show_student() 'show_student'
# func = getattr(alex,'show_student')
# func() # hasattr getattr delattr
# if hasattr(Teacher,'dic'):
# ret = getattr(Teacher,'dic') # Teacher.dic # 类也是对象
# ret2 = getattr(Teacher,'func') # 类.方法 Teacher.func
# print(ret)
# print(ret2)
# ret2()
# menu = Teacher.dic
# # for k in menu:
# # print(k)
# 通过反射
# 对象名 获取对象属性 和普通方法
# 类名 获取静态属性 和 类方法 和 静态方法
普通方法 带self
静态方法 @staticmethod
类方法 @classmethod
属性方法 @property

python学习之老男孩python全栈第九期_day026知识点总结——封装、property、类方法、初识反射的更多相关文章

  1. python学习之老男孩python全栈第九期_day027知识点总结——反射、类的内置方法

    一. 反射 ''' # isinstance class A:pass class B(A):pass a = A() print(isinstance(a,A)) # 判断对象和类的关系 print ...

  2. python学习之老男孩python全栈第九期_day023知识点总结——类和对象命名空间、组合

    一. 类和对象命名空间类里 可以定义两种属性: 1. 静态属性 2. 动态属性 class Course: language = 'Chinese' def __init__(self, teache ...

  3. python学习之老男孩python全栈第九期_day019知识点总结——collections模块、时间模块、random模块、os模块、sys模块

    一. collections模块 在内置数据类型(dict.list.set.tuple)的基础上,collections模块还提供了几个额外的数据类型:namedtuple.deque.Counte ...

  4. python学习之老男孩python全栈第九期_day017知识点总结——初识递归、算法

    一. 递归函数 如果一个函数在内部调用自身本身,这个函数就是递归函数. 最大递归深度默认是997 -- python从内存角度出发做得限制(而不是程序真的报错),最大深度可以修改 def func(n ...

  5. python学习之老男孩python全栈第九期_day010知识点总结

    def qqxing(l = []): # 可变数据类型 l.append(1) print(l)qqxing() # [1]qqxing([]) # [1]qqxing() # [1, 1]qqxi ...

  6. python学习之老男孩python全栈第九期_day007知识点总结

    基础数据类型汇总 1. str 2. int 3. list 4. bool 5. dict (1) fromkeys Python 字典 fromkeys() 方法用于创建一个新的字典,并以可迭代对 ...

  7. python学习之老男孩python全栈第九期_day001知识点总结

    1. Python2与Python3的区别: Python2:源码不标准,混乱,重复代码太多: Python3:统一标准,去除重复代码. 编码方式: python2的默认编码方式为ASCII码:pyt ...

  8. python学习之老男孩python全栈第九期_day014知识点总结

    # 迭代器和生成器# 迭代器 # 双下方法:很少直接调用的方法,一般情况下,是通过其他语法触发的# 可迭代的 --> 可迭代协议:含有__iter__的方法( '__iter__' in dir ...

  9. python学习之老男孩python全栈第九期_day016知识点总结

    '''数据类型:intbool... 数据结构:dict (python独有的)listtuple (pytho独有的)setstr''' # reverse() 反转l = [1,2,3,4,5]l ...

随机推荐

  1. JMeterPlugin性能监控

    GUI界面中的plugins manager中的jpgc-Standard set,其中共包含以下的文件: jpgc-dummy jpgc-fifo jpgc-graphs-basic jpgc-pe ...

  2. FutureTask与Fork/Join

    在学习多线程的过程中,我们形成了一种思维习惯.那就是对于某个耗时操作不再做同步操作,让他分裂成一个线程之后执行下一步,而线程执行耗时操作.并且我们希望在我们需要它返回的时候再去调用它的结果集.好比我们 ...

  3. canvas+js绘制序列帧动画+面向对象

    效果: 素材: 源码:(一般的绘制方式) <!DOCTYPE html> <html lang="en"> <head> <meta ch ...

  4. 钩子编程(HOOK) 屏蔽全部按键、鼠标及系统功能键 (4)

    摘要:上篇文章<钩子编程(HOOK) 安装系统全局钩子>已经具体的解说了全局钩子的安装.本文将增强一下钩子的功能.实现屏蔽全部按键鼠标与系统功能键.要实现这个功能.须要安装两个全局钩子,& ...

  5. 常见的http错误提示

    1xx(临时响应)表示临时响应并需要请求者继续执行操作的状态代码. 代码 说明100 (继续) 请求者应当继续提出请求.服务器返回此代码表示已收到请求的第一部分,正在等待其余部分. 101 (切换协议 ...

  6. [温故]图解java多线程设计模式(一)

    去年看完的<图解java多线程设计模式>,可惜当时没做笔记,导致后来忘了许多东西,打算再温习下这本书,顺便在这里记录一下~  1.顺序执行.并行.并发 顺序执行:多个操作按照顺序依次执行. ...

  7. Mac OS 10.12后Caps lock(大写键)无法使用的解决办法

    ▲打开设置中的键盘选项,并切换至输入源选项标签, ▲取消勾选“使用大写锁定键来回切换“美国英文””, ▲这时再按下Caps lock即可正常使用大小写切换. ▲Update:目前macOS 10.12 ...

  8. vSphere通过Client创建Centos7主机

    准备: vSphere Client 客户端 Centos7官方镜像,本次采用的是CentOS-7-x86_64-Minimal-1511.iso 创建过程: 1.登录vSphere虚拟主机,输入账户 ...

  9. Struts2 extends用法

    1.创建一个struts-extends.xml文件 <?xml version="1.0" encoding="UTF-8"?> <!DOC ...

  10. 使用 Python 编写脚本并发布

    使用 Python 编写脚本并发布 P1: 脚本 通常在 Linux 服务器上会遇到在命令行中输入命令的操作,而有些操作包含的命令数目较多或者其中的命令包含的参数较多,如果一个一个的敲命令的话就太麻烦 ...