property

property是一种特殊的属性,访问它时会执行一段功能(函数)然后返回值;就是把一个函数属性的访问方式变成像访问数据属性的方式一样。

我们首先来看一个对比效果

例一:在调用 bmi 函数的时候需要加括号的,可是我们往往需要另一种调用方法——不想加括号

class people():
def __init__(self, name, height, weight):
self.name = name
self.height = height
self.weight = weight def bmi(self):
return self.weight / (self.height ** 2) p = people('ysg', 1.8, 75)
print(p.bmi())
# 结果:23.148148148148145

例二:使用 property 后,则调用不需要在使用括号了

class people():
def __init__(self, name, height, weight):
self.name = name
self.height = height
self.weight = weight @property
def bmi(self):
return self.weight / (self.height ** 2) p = people('ysg', 1.8, 75)
print(p.bmi)
# 结果:23.148148148148145
# 使用加括号调用的会报错:TypeError: 'float' object is not callable
property 的其他用法,并不常用
前提条件
class people():
def __init__(self, name):
self.__name = name @property
def name(self):
return self.__name p = people('ysg')
print(p.name)
setter、deleter 的使用
class people():
def __init__(self, name):
self.__name = name @property
def name(self):
return self.__name @name.setter
def name(self, val):
if not isinstance(val, str):
print('格式不是 str,不允许被修改')
return
self.__name = val
@name.deleter
def name(self):
print('不允许被删除') 修改
p = people('ysg')
p.name = 'ysging'
print(p.name)
结果:ysging p.name = 213
print(p.name)
结果:
格式不是 str,不允许被修改
ysg 删除
del p.name
print(p.name)
结果:
不允许被删除
ysg
property 意义在于:将一个类的函数定义成特性以后,对象再去使用的时候obj.name,根本无法察觉自己的 name 是执行了一个函数然后计算出来的,这种特性的使用方式遵循了统一访问的原则

绑定方法

在类内部定义的函数,分为两大类

一:绑定方法

  绑定给谁,就应该由谁来调用,谁来调用就会把调用者当作第一个参数自动传入

    绑定对象的方法:在类内定义的没有被任何装饰器修饰的

    绑定到类的方法:在类内定义的被装饰器 classmethod 修饰的方法

二:非绑定方法

  不与类或者对象绑定,没有自动传值
  就是在类中定义一个普通的函数或工具,对象和类都可以调用,都需要传值

绑定对象的方法

class Foo():
def __init__(self, name):
self.name = name def tell(self):
print('this is %s' % self.name) @classmethod
def func(cls):
print() f = Foo('ysg')
f.tell() # this is ysg
print(f.tell) # <bound method Foo.tell of <__main__.Foo object at 0x000001E5BED2F390>>
print(Foo.tell) # <function Foo.tell at 0x000001E5BED31268>
Foo.tell(f) # 使用类来调用 this is ysg

绑定到类的方法

class Foo():
def __init__(self, name):
self.name = name @classmethod
def func(cls):
print(cls) f = Foo('ysg')
print(Foo.func) # <bound method Foo.func of <class '__main__.Foo'>>
Foo.func() # <class '__main__.Foo'>
print(Foo) # <class '__main__.Foo'>

非绑定方法

class Foo():
def __init__(self, name):
self.name = name @staticmethod
def func(x, y):
print(x + y) f = Foo('ysg')
print(Foo.func) # <function Foo.func at 0x0000021B45FE1268>
print(f.func) # <function Foo.func at 0x0000021B45FE1268>
f.func(1, 2) #
Foo.func(1, 2) #

使用场景

总结:使用哪种方法,取决于函数体的逻辑来进行判断应该传什么参数。

例子:绑定到对象

class People():
def __init__(self, name, age, sex):
self.name = name
self.age = age
self.sex = sex def tell(self):
print('姓名:{0},年龄:{1},性别:{2}'.format(self.name, self.age, self.sex)) p = People('ysg', 21, 'man')
p.tell() # 姓名:ysg,年龄:21,性别:man

例子:绑定到类

前提条件,从配置文件中取值

configs.py

name = 'ysging'
age = 15
sex = 'man'
import configs
class People():
def __init__(self, name, age, sex):
self.name = name
self.age = age
self.sex = sex def tell_info(self):
print('姓名:{0},年龄:{1},性别:{2}'.format(self.name, self.age, self.sex)) @classmethod
def tell(cls):
p = cls(
configs.name,
configs.age,
configs.sex
)
return p p = People.tell()
p.tell_info() #姓名:ysging,年龄:15,性别:man

例子:非绑定方法,给每一个实例分配 id

import time
import hashlib class People():
def __init__(self, name, age, sex):
self.name = name
self.age = age
self.sex = sex
self.id = self.ids() @staticmethod
def ids():
time.sleep(0.01)
m = hashlib.md5(str(time.time()).encode('utf-8'))
return m.hexdigest() p = People('ysg1', 21, 'man')
p2 = People('ysg2', 22, 'man')
p3 = People('ysg3', 23, 'man') print(p.id) # 44261d399ba9650c628cb8d189ffdd0b
print(p2.id) # 2c7270c27984119c7cf39e9d575f07bd
print(p3.id) # 4c386111edf4f641f7c35bb855d1551a

day 26-1 property、绑定与非绑定方法的更多相关文章

  1. python面向编程;类的绑定与非绑定方法、反射、内置方法

    一.类的绑定与非绑定方法 ''' 类中定义函数分为了两大类: 1. 绑定方法 特殊之处: 绑定给谁就应该由谁来调用,谁来调用就会将谁当做第一个参数自动传入 绑定给对象的方法: 在类中定义函数没有被任何 ...

  2. 封装、property特性及绑定与非绑定方法

    1.封装 (1)什么是封装? 封:属性对外是隐藏的,但对内是开放的: 装:申请一个名称空间,往里面装入一系列名字/属性 (2)为什么要封装? 封装数据属性的目的 首先定义属性的目的就是为了给类外部的使 ...

  3. python 类的封装/property类型/和对象的绑定与非绑定方法

    目录 类的封装 类的property特性 类与对象的绑定方法与非绑定方法 类的封装 封装: 就是打包,封起来,装起来,把你丢进袋子里,然后用绳子把袋子绑紧,你还能拿到袋子里的那个人吗? 1.隐藏属性和 ...

  4. python 面向对象(类的成员,属性,绑定和非绑定,)

    面向对象是一种编程方式,此编程方式的实现是基于对 类 和 对象 的使用 类 是一个模板,模板中包装了多个“函数”供使用(可以讲多函数中公用的变量封装到对象中) 对象,根据模板创建的实例(即:对象),实 ...

  5. Day08:继承与派生,多态,封装,绑定与非绑定方法,面向对象高级(反射,__str__,__del__)

    上节课复习:1.编程思想    面向过程        核心是过程二字,过程指的是解决问题的步骤,即先干什么再干什么后干什么        基于该思想编写程序就好比在设计一条流水线,是一种机械式的思维 ...

  6. 绑定与非绑定方法及反射,isinstance和issubclass内置函数

    目录 绑定方法与非绑定方法 1.绑定方法 2.非绑定方法(staticmethod) isinstance和issubclass 内置函数 1.isinstance 2.issubclass 反射(面 ...

  7. CSIC_716_20191128【多态、绑定与非绑定方法、isinstance与issubclass 】

    多态 what: 同一个事物有不同的形态. 多态的目的:在不知道对象具体类型的情况下,统一对象调用方法的规范.(通俗讲,即规定实现同样功能的方法,一定要起同样的名字). 多态的表现形式之一就是继承,先 ...

  8. 绑定与非绑定以及property装饰器_day_21 作业题

    1.定义MySQL类 1.对象有id.host.port三个属性 2.定义工具create_id,在实例化时为每个对象随机生成id,保证id唯一 3.提供两种实例化方式,方式一:用户传入host和po ...

  9. bound和unbound方法,类的绑定和非绑定是什么

    作者:灵剑链接:https://www.zhihu.com/question/41006598/answer/148994582来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明 ...

随机推荐

  1. 纯CSS背景噪声.html

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  2. JAVA学习第一课-手工笔记

    JVM:JAVA虚拟机,JAVA核心,跨平台,作用是翻译. JRE:运行环境,包含JVM和运行的核心类库. JDK:全新开发使用,包含JRE,编译工具: 核心是JVM 以下是关系库 安装路径不要有空格 ...

  3. 《手把手教你》系列进阶篇之2-python+ selenium自动化测试 - python基础扫盲(详细教程)

    1. 简介 这篇文章主要是分享讲解一下,如何封装自己用到的方法和类.以便方便自己和别人的调用,这样就可以避免重复地再造轮子. 封装(Encapsulation)是面向对象的三大特征之一(另外两个是继承 ...

  4. 你真的了解JSON吗?

    一.JSON——JavaScript Object Notation JSON 是一种语法用来序列化对象.数组.数值.字符串.布尔值和null .它基于 JavaScript 语法,但与之不同:一些J ...

  5. mininet(一)实验环境搭建

    mininet(一)实验环境搭建 mininet(二)简单的路由实验 mininet(三)简单的NAT实验 最近学习(https://github.com/mininet/openflow-tutor ...

  6. HDU5343 MZL's Circle Zhou(SAM+记忆化搜索)

    Problem Description MZL's Circle Zhou is good at solving some counting problems. One day, he comes u ...

  7. Selenium之编辑框操作

    编辑框操作: 网页上随处可见的编辑框,有时候编辑框里有默认的提示文字或者当我们需要输入第二次测试数据时,须先用clear()方法清除该元素里的字符串,再输入文本: 那么如何获取输入框已经输入的文本内容 ...

  8. Python3 类与对象之王者荣耀对战小游戏

    王者荣耀对战小游戏 # 定义英雄: 亚瑟 class Arthur: hero_type = 'Tank' def __init__(self, attack_value=164, armor=98, ...

  9. ==和equals的深度分析

    ==的分析 1.对于基本数据类型,比较的是他们的具体内容是不是一样,跟他们的内存地址无关.举个栗子: public class Test{ public static void main(String ...

  10. vue-cli开发项目,调用html5+接口,hbuilder真机运行,打包

    开发中使用vue-cli正常开发 将配置文件中的路径改为相对路径--否则在打包之后真机运行时无法找到指定路径 开发完或者开发途中想要查看调用h5+的api效果就需要打包了 npm run build ...