基本行为和属性

__init__(self[,....])构造函数 . 在实例化对象的时候会自动运行

__del__(self)析构函数 . 在对象被回收机制回收的时候会被调用

__str__(self)输出函数 . 在实例对象请求输出的时候会被调用.

__repr__(self). 当直接调用实例对象的时候会被调用

__new__(cls,[,...]). 她的第一个参数是这个类 , 其他的参数被直接传送到 __init__ . 并且__new__是一个对象实例化的时候所调用的第一个方法(所以可以在这里做点手脚) ,

__bool__(self)  定义当被bool类 调用的时候 应当返回的值

__len__(self) 定义单被len调用的时候的行为.

__hash__(self) 定义当被hash 调用的时候返回的函数 .

__getattr__ (self,name)定义当用户师徒访问一个不存在的属性时 所执行的行为 .

__getattribute__(self,name)定义当该属性被访问时的行为

__setattribute__ (self,name,value)定义一个属性被设置时的行为 .

__delattr__(self,name)定义一个属性被删除时的行为

__dir__(self) 定义dir被调用时的行为.

__get__(self,instance,owner) 定义当描述符 被取得时的行为

__set__(self,instance,owner)定义当描述符的值被改变是的行为.

__delete__(self,instance) 定义当描述符被删除时的行为

比较操作符,算术运算符,反运算,增量运算,一元操作,类型转换,上下文管理,容器类型.

详见http://bbs.fishc.com/thread-48793-1-2.html

当属性的名称和方法的名称一样的时候 , 属性的名称会自动覆盖方法的名称  , 所以属性和方法的名称影噶尽量分开 .

 import time as t
import sys class MyTimer():
def __init__(self): # 上去先设置 各种属性防止 使用不当出错 .
self.unit=['年','月','日','小时','分钟','秒']
self.prompt='未开始计时.'
self.lasted=[]
self.begin=0
self.end=0 def __str__(self):
print('我被调用了 .')
return self.prompt __repr__=__str__ def start(self):
self.begin=t.localtime()
print('开始计时') def stop(self):
if not self.begin:
print("请先开始调用 start")
else:
self.end=t.localtime()
self._calc()
print('计时结束') def _calc(self):
self.lasted=[]
self.prompt='总共运行了'
for index in range(6):
self.lasted.append(self.end[index]-self.begin[index])
if self.lasted[index]:
self.prompt+=str(self.lasted[index])+self.unit[index]
 Python 3.5.2 (v3.5.2:4def2a2901a5, Jun 25 2016, 22:01:18) [MSC v.1900 32 bit (Intel)] on win32
Type "copyright", "credits" or "license()" for more information.
>>>
=============== RESTART: C:/Users/Administrator/Desktop/new.py ===============
>>> t1=MyTimer()
>>> t1
我被调用了 .
未开始计时.
>>> t1
我被调用了 .
未开始计时.
>>> t1.Stop()
请先开始调用 start
>>> t1.Start()
开始计时
>>> t1.Stop()
计时结束
>>> t1
我被调用了 .
总共运行了5秒
>>> print(t1)
我被调用了 .
总共运行了5秒
>>>

魔法方法的坑 , 和常见的躲坑方法 .

 # 这是一个 求面积的程序( 很显然有坑 ) , 如果属性名定义为 square的话 就默认 width=height
class Rectangle:
def __init__(self,width=0,height=0):
self.width=width
self.height=height def __setattr__(self,name,value):
if name=='suqare':
self.width=valuc
self,height=value
else:
#super().__setattr__(name,value)
self.name=value #如果程序是这样的话实例化对象的时候会出现无限递归 为啥呢? def GetArea(self): # 在 最初的 init 那里开始对一个不存在的属性进行赋值 然后就调用了 setattr 调用 setattr的时候 又有 对 该属性(不存在.)进行赋值 然后就递归了.
return self.width*self.height # 解决的办法就是 在出错的地方使用官方提供的 方法 super().__setattr__(name,value)
 >>> c1=Rectangle()
Traceback (most recent call last):
File "<pyshell#0>", line 1, in <module>
c1=Rectangle()
File "C:\Users\Administrator\Desktop\new.py", line 3, in __init__
self.width=width
File "C:\Users\Administrator\Desktop\new.py", line 12, in __setattr__
self.name=value #如果程序是这样的话实例化对象的时候会出现无限递归 为啥呢?
File "C:\Users\Administrator\Desktop\new.py", line 12, in __setattr__
self.name=value #如果程序是这样的话实例化对象的时候会出现无限递归 为啥呢?
File "C:\Users\Administrator\Desktop\new.py", line 12, in __setattr__
self.name=value #如果程序是这样的话实例化对象的时候会出现无限递归 为啥呢?
File "C:\Users\Administrator\Desktop\new.py", line 12, in __setattr__
self.name=value #如果程序是这样的话实例化对象的时候会出现无限递归 为啥呢?
File "C:\Users\Administrator\Desktop\new.py", line 12, in __setattr__
self.name=value #如果程序是这样的话实例化对象的时候会出现无限递归 为啥呢?
...
...
...
File "C:\Users\Administrator\Desktop\new.py", line 12, in __setattr__
self.name=value #如果程序是这样的话实例化对象的时候会出现无限递归 为啥呢?
File "C:\Users\Administrator\Desktop\new.py", line 12, in __setattr__
self.name=value #如果程序是这样的话实例化对象的时候会出现无限递归 为啥呢?
RecursionError: maximum recursion depth exceeded while calling a Python object
>>>

上面的坑 详见 源代码注释 .

躲开这些坑的办法就是 当你重写这些魔法方法之后 , 剩余的 就让原来的官方方法就解决 .

 # 这是一个 求面积的程序 , 如果属性名定义为 square的话 就默认 width=height
class Rectangle:
def __init__(self,width=0,height=0):
self.width=width
self.height=height def __setattr__(self,name,value):
if name=='suqare':
self.width=valuc
self,height=value
else:
self.__dict__[name]=value
#super().__setattr__(name,value)
#self.name=value #如果程序是这样的话实例化对象的时候会出现无限递归 为啥呢? def GetArea(self): # 在 最初的 init 那里开始对一个不存在的属性进行赋值 然后就调用了 setattr 调用 setattr的时候 又有 对 该属性(不存在.)进行赋值 然后就递归了.
return self.width*self.height # 解决的办法就是 在出错的地方使用官方提供的 方法 super().__setattr__(name,value)
 =============== RESTART: C:\Users\Administrator\Desktop\new.py ===============
>>> r1=Rectangle(4,5)
>>> r1.__dict__ # 将该实例化对象的 所有属性 打印出来
{'height': 5, 'width': 4}
>>> r1.GetArea()
20
=============== RESTART: C:\Users\Administrator\Desktop\new.py ===============
>>> r1=Rectangle(4,5)
>>> r1.__dict__
{'width': 4, 'height': 5}
>>> # 显然是可以的 .

Python的魔法方法 .的更多相关文章

  1. python之魔法方法介绍

    1.1. 简介 什么是魔法方法呢?它们在面向对象的Python的处处皆是.它们是一些可以让你对类添加“魔法”的特殊方法. 它们经常是两个下划线包围来命名的(比如 __init__ , __lt__ ) ...

  2. 【Python】 魔法方法

    魔法方法 这个名字真的很中二有没有 = =(或者说翻译气息太浓了,作为一个学外语的看到这种真是想吐槽的不行..) 从形式上来说,在方法的名字前后个加上两条下划线的就是魔法方法了 .从功能上说,所有魔法 ...

  3. python,魔法方法指南

    1.简介 本指南归纳于我的几个月的博客,主题是 魔法方法 . 什么是魔法方法呢?它们在面向对象的Python的处处皆是.它们是一些可以让你对类添加“魔法”的特殊方法. 它们经常是两个下划线包围来命名的 ...

  4. python中魔法方法__init__,__str__,__del__的详细使用方法

    1. python中的魔法方法, 类似__init__, __str__等等,这些内置好的特定的方法进行特定的操作时会自动被调用 2. __init__的使用方法 class 类名(object):  ...

  5. 21 python的魔法方法(转)

    魔法方法 含义   基本的魔法方法 __new__(cls[, ...]) 1. __new__ 是在一个对象实例化的时候所调用的第一个方法2. 它的第一个参数是这个类,其他的参数是用来直接传递给 _ ...

  6. Python的魔法方法??

    就是可以给你的类增加魔力的特殊方法,如果你的对象实现 (重载)了这些方法中的某一个,那么这个方法就会在特殊的情况下被 Python 所调用,你可以定义自己想要的行为,而这一切都是自动发生的. __in ...

  7. python基础--魔法方法、迭代器、上下文管理

    isinstance:判断一个对象是否是某个类的实例 参数一:要判断的对象 参数二:要判断的类型 issubclass:判断一个类是否是另一个类的子类 参数一:是待判断的子类 参数二:待判断的父类 _ ...

  8. Python随笔--魔法方法(析构与构造)

    #析构方法的调用

  9. python中魔法方法(持续更新)

    1.对于一个自定义的类,如果实现了 __call__ 方法,那么该类的实例对象的行为就是一个函数,是一个可以被调用(callable)的对象.例如: class Add: def __init__(s ...

随机推荐

  1. 谈谈JPA-04-JPA的常用API

    JPA相关接口/类: Persistence Persistence  类是用于获取 EntityManagerFactory 实例.该类包含一个名为 createEntityManagerFacto ...

  2. 关于JVM的类型和模式

    原文出处: 摆渡者 引言 曾几何时,我也敲打过无数次这样的命令: 然而之前的我都只关心过版本号,也就是第一行的内容.今天,我们就来看看第3行输出的内容:JVM的类型和工作模式. 其实说Server和C ...

  3. hdu-----2491Priest John's Busiest Day(2008 北京现场赛G)

    Priest John's Busiest Day Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Jav ...

  4. Echart多图联动

    1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 3 ...

  5. SAP销售订单状态修改(审核) 计划行自动产生需求,产生MD04需求

    不知道业务怎么配置的,创建销售单时,一堆计划行类别,什么CN,DN...都有,但是审核后需要计划行变更为CP,这样在MD04才能看到需求. 原有逻辑是弄个后台程序,审核后调一下,更新一下计划行,这样是 ...

  6. Anysys Fluent安装教程

    按顺序按照在一个文件夹内D:\Anysys Fluent 1:安装Exceed      调整电脑时间至2005年(前辈经验)      点击解压好的Exceed.13.[x86+x64]文件夹中的M ...

  7. NetworkComms网络通信框架V3结构图

    NetworkComms网络通信框架序言 来自英国的c#网络通信框架,历时五年打造,由英国剑桥的2位工程师倾情开发,最新版本V3.x版本.

  8. [css3]文字过多以省略号显示

    text-overflow:ellipsis; 优点: 1.不用通过程序限定字数 2.有利于SEO(实际上并未被截字,只是局限于宽度未被显示而已) width: 某个值; overflow: hidd ...

  9. 一个高在线(可以超过1024)多线程的socket echo server(pthreads 和 libevent扩展)

    研究了3周吧,本来打算用pthreads+event扩展的,结果event扩展太原始了,太多函数了,实在不知道怎么在外部随时发送数据给客户端,所以改用libevent, 改用libevent之后花了2 ...

  10. ubuntu 14.04 上安装有道词典

    Ubuntu 14.04用户在安装前要更新系统,即update&dist-upgrade. 下载地址:32/64bits http://codown.youdao.com/cidian/lin ...