Python的魔法方法 .

基本行为和属性

__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

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

 1 import time as t
 2 import sys
 3 
 4 class MyTimer():
 5     def __init__(self):   # 上去先设置 各种属性防止 使用不当出错 . 
 6         self.unit=['','','','小时','分钟','']
 7         self.prompt='未开始计时.'
 8         self.lasted=[]
 9         self.begin=0
10         self.end=0
11     
12     def __str__(self):
13         print('我被调用了 .')
14         return self.prompt
15 
16     __repr__=__str__
17 
18     def start(self):
19         self.begin=t.localtime()
20         print('开始计时')
21 
22     def stop(self):
23         if not self.begin:
24             print("请先开始调用 start")
25         else:
26             self.end=t.localtime()
27             self._calc()
28             print('计时结束')
29 
30     def _calc(self):
31         self.lasted=[]
32         self.prompt='总共运行了'
33         for index in range(6):
34             self.lasted.append(self.end[index]-self.begin[index])
35             if self.lasted[index]:
36                 self.prompt+=str(self.lasted[index])+self.unit[index]

 

 1 Python 3.5.2 (v3.5.2:4def2a2901a5, Jun 25 2016, 22:01:18) [MSC v.1900 32 bit (Intel)] on win32
 2 Type "copyright", "credits" or "license()" for more information.
 3 >>> 
 4 =============== RESTART: C:/Users/Administrator/Desktop/new.py ===============
 5 >>> t1=MyTimer()
 6 >>> t1
 7 我被调用了 .
 8 未开始计时.
 9 >>> t1
10 我被调用了 .
11 未开始计时.
12 >>> t1.Stop()
13 请先开始调用 start
14 >>> t1.Start()
15 开始计时
16 >>> t1.Stop()
17 计时结束
18 >>> t1
19 我被调用了 .
20 总共运行了5秒
21 >>> print(t1)
22 我被调用了 .
23 总共运行了5秒
24 >>> 

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

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

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

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

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

 

转载于:https://www.cnblogs.com/A-FM/p/5678231.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/287007.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

游戏角色开始动起来了,真帅!【python 游戏实战 03】

前言 本系列文章将会以通俗易懂的对话方式进行教学&#xff0c;对话中将涵盖了新手在学习中的一般问题。此系列将会持续更新&#xff0c;包括别的语言以及实战都将使用对话的方式进行教学&#xff0c;基础编程语言教学适用于零基础小白&#xff0c;之后实战课程也将会逐步更新…

如何让 ASP.NET Core 支持绑定查询字符串中的数组

前言有网友在交流群中询问&#xff0c;如何让 ASP.NET Core 支持绑定查询字符串中的数组&#xff1a;据说&#xff0c;在 .NET 7 中已经支持了&#xff1a;但是&#xff0c;在这之前的 .NET 版本能实现相同功能吗&#xff1f;ByteArrayModelBinder这时&#xff0c;群里的网友提…

Docker Storm开发环境搭建

2019独角兽企业重金招聘Python工程师标准>>> 1. compose文件 storm-stack.yml version: 3.1services:zookeeper:image: zookeepercontainer_name: zookeeperrestart: alwaysports:- 2181:2181nimbus:image: stormcontainer_name: nimbuscommand: storm nimbusdepend…

Android之解决YouTubePlayerView启动在Android5.0左右的手机出现奔溃问题

1 问题 用YouTubePlayerView(https://github.com/PierfrancescoSoffritti/android-youtube-player)在部分Android5.0手机上初始化的时候出现手机奔溃,错误提示如下 关键日志如下: Error inflating class com.pierfrancescosoffritti.androidyoutubeplayer.core.player.v…

重庆大学计算机课程设计,计算机组成原理课程设计报告重庆大学.doc

计算机组成原理课程设计报告重庆大学计算机组成原理课程设计报告题目&#xff1a;微程序设计专业&#xff1a;计算机科学与技术班级&#xff1a;指导老师&#xff1a;目录一、摘要二、设计要求三、微程序控制器原理四、总体设计五、测试六、结论七、参考文献目录八、 个人总结重…

一些服务器编程的概念

IO线程&#xff1a;有Event loop的线程&#xff0c;每个线程有且有一个loop&#xff0c;用per thread变量记录这个loop的对象地址&#xff0c;如果这个变量非空可以知道这个线程是IO线程 Channel&#xff1a;绑定到一个且只能一个loop&#xff0c;即某个IO线程&#xff0c;负责…

南方方洲号无人测量船系统简介

南方智能测量船系统由小型无人船、自动导航模块、声纳探测模块、外围传感模块、岸基操控终端、无人船专用软件等部分组成。将先进的卫星定位、声纳、传感器与智能导航控制等众多技术相结合,提出了高精度、智能化、集成化、机动化、网络化的勘测解决方案。该系统能自主航行并完…

1小时1篇文学会python再做个飞机大战游戏

注&#xff1a; 想慢慢学习的同学可以看我的 《python 入门到游戏实战专栏》&#xff08;更新中&#xff09; 想学 C 的同学可以看《大话系列之C语言》&#xff08;基本更新完&#xff09; 想学 C 的同学可以看《大话C》&#xff08;更新中&#xff09; 想做习题的可以看《大学…

Android之app作为服务器解决跨域问题

1 问题 APP用socket写了服务器,然后PC发送请求到APP出现跨域问题。 2 解决办法 在APP用socket服务器返回头里面添加如下关键代码 header="Content-Type: "+ JSON_TYPE + "; charset=utf-8 \r\n"+ "Connection: close\r\n"+ "Access-Cont…

如何优雅的编写git的提交信息

前言在公司的日常工作当中或者个人的开源项目&#xff0c;将代码提交到代码库时。都会遇到下面这样的对话框&#xff0c;通常都会随便写点内容在里面。当遇到问题需要回溯的时候就成了给自己造成的麻烦&#xff0c;因为无法通过commit message来非常直观的看到这一次提交了什么…

android快捷开发之Retrofit网络加载框架的简单使用

大家都知道&#xff0c;安卓最大的特点就是开源化&#xff0c;这自然会产生很多十分好用的第三方API&#xff0c;而基本每一个APP都会与网络操作和缓存处理机制打交道&#xff0c;当然&#xff0c;你可以自己通过HttpUrlConnection再通过返回数据进行解析解决&#xff0c;而我们…

如何线性求乘法逆元

ny[i](ny[p%i]*(p-p/i))%p;不如背一发板子&#xff1f;转载于:https://www.cnblogs.com/paozi/p/7788640.html

打开计算机无法显示工具栏,任务栏不显示打开的窗口怎么办教程

我们在使用电脑的时候&#xff0c;打开很多程序的时候&#xff0c;会最小化某些窗口&#xff0c;只留在用的窗口&#xff0c;而最小化都是缩小为一个图标放入屏幕下方的任务栏的&#xff0c;但有时候不知道为什么任务栏不显示打开的窗口了&#xff0c;这时候也就无法直接用鼠标…

rsync文件同步、Inotify-tools参数详解

inotifywait用于等待文件或文件集上的一个待定事件&#xff0c;可以监控任何文件和目录设置&#xff0c;并且可以递归地监控整个目录树&#xff1b; inotifywatch用于收集被监控的文件系统计数据&#xff0c;包括每个inotify事件发生多少次等信息从上面可知inotifywait是一个…

ArcGIS 10.6提取道路中心线的两种方法经典教程

我们工作中碰到的道路数据通常为面状,需要提取道路中心线,本文讲解ArcGIS10.6中从面状道路数据中提取道路中心线的两种常用经典方法。 方法一:使用ArcGIS 10.6提供的提取道路中心线工具 本实验中使用到面状数据如下所示: 首先,将面状数据转为线状数据。 转完之后,道路尽头…

衡量计算机浮点数操作性能,计算机系统基础:计算机性能评价知识笔记

1、计算机性能常用的性能评测方法1.1 时钟频率计算机的时钟频率可以反映出机器的运行速度。一般主频越高&#xff0c;速度越快。1.2 指令执行速度加法指令执行速度是衡量计算机性能指标的重要指标之一。1.3 等效指令速度法随着计算机指令系统发展&#xff0c;种类越来越多&…

Android之用HttpURLConnection断点下载谷歌云存储(google cloud storage)文件

1 需求 在Android app里面实现断点下载谷歌云存储(google cloud storage)文件,也就是说用户下载谷歌云存储(google cloud storage)文件的时候可以暂停下载,后续可以再继续下载 测试的图片谷歌云的下载地址:https://storage.googleapis.com/keepdrop/common_dev/file-6fb695ac…

python 写游戏好简单啊,我用键盘可以随意控制角色了【python 游戏实战 04】

前言 本系列文章将会以通俗易懂的对话方式进行教学&#xff0c;对话中将涵盖了新手在学习中的一般问题。此系列将会持续更新&#xff0c;包括别的语言以及实战都将使用对话的方式进行教学&#xff0c;基础编程语言教学适用于零基础小白&#xff0c;之后实战课程也将会逐步更新…

ASP.NET登录以及注册

数据模型&#xff1a; 1 public class Model2 {3 public Model()4 {5 //6 // TODO: 在此处添加构造函数逻辑7 //8 }9 private string _Ucode; 10 /// <summary> 11 /// 账号 12 /// </summary> 13 public…

树形表的平行查询设计

本文由网友长空X投稿&#xff0c;欢迎转载、分享原文作者&#xff1a;长空X&#xff08;CSDN同名“长空X“&#xff0c;CkTools的作者&#xff0c;github: https://github.com/hjkl950217&#xff09;原文链接&#xff1a;https://www.cnblogs.com/gtxck/articles/16293295.htm…