1. Python 魔法方法
Python 魔法方法

基础:
| 如果你想... | 所以,你写... | Python调用... |
|---|---|---|
| 初始化一个实例 | x = MyClass() |
x.__init__() |
| 作为一个字符串的"官方"表示 | repr(x) |
x.__repr__() |
| 作为一个字符串 | str(x) |
x.__str__() |
| 作为字节数组 | bytes(x) |
x.__bytes__() |
| 作为格式化字符串 | format(x, format_spec) |
x.__format__(format_spec) |
__init__()方法在创建实例后调用.如果你想控制创建过程,请使用__new__()方法- 按照惯例,
__repr__()应该返回一个有效的Python表达式的字符串 __str__()方法也被称为你的print(x)
迭代相关
| 如果你想... | 所以,你写... | Python调用... |
|---|---|---|
| 遍历一个序列 | iter(seq) |
seq.__iter__() |
| 从迭代器中获取下一个值 | next(seq) |
seq.__next__() |
| 以相反的顺序创建一个迭代器 | reversed(seq) |
seq.__reversed__() |
__iter__()无论何时创建新的迭代器,都会调用该方法.__next__()每当你从迭代器中检索一下个值的时候,都会调用该方法__reversed__()方法并不常见.它需要一个现有序列并返回一个迭代器,该序列是倒序的顺序.
属性
| 如果你想... | 所以,你写... | Python调用... |
|---|---|---|
| 得到一个属性 | x.my_property |
x.__getattribute__('my_property') |
| 获得一个属性 | x.my_property |
x.__getattr__('my_property') |
| 设置一个属性 | x.my_property = value |
x.__setattr__('my_property', value) |
| 阐述一个属性 | del x.my_property |
x.__delattr__('my_property') |
| 列出所有属性和方法 | dir(x) |
x.__dir__() |
- 如果你的类定义了一个
__getattribute__()方法,Python将在每次引用任何属性或方法名时调用它. - 如果你的类定义了一个
__getattr__()方法,Python只会在所有普通地方查找属性后调用它.如果一个实例x定义了一个属性color,x.color将不会调用x.__getattr__('color'); 它将简单地返回已经定义的x.color值. __setattr__()只要你为属性指定值,就会调用该方法.__delattr__()只要删除属性,就会调用该方法.__dir__()如果您定义一个__getattr__()或者__getattribute__()方法,该方法很有用.通常情况下,调用dir(x)只会列出常规属性和方法.
__getattr__()和__getattribute__()方法之间的区别很微妙但很重要.
函数类
通过定义call()方法,您可以创建一个可调用类的实例 - 就像函数可调用一样.
| 如果你想... | 所以,你写... | Python调用... |
|---|---|---|
| 来"调用"像函数一样的实例 | my_instance() |
my_instance.__call__() |
行为
如果你的类作为一组值的容器 - 也就是说,如果问你的类是否"包含"一个值是有意义的 - 那么它应该定义下面的特殊方法,使它像一个集合一样.
| 如果你想... | 所以,你写... | Python调用... |
|---|---|---|
| 序列的数量 | len(s) |
s.__len__() |
| 否包含特定的值 | x in s |
s.__contains__(s) |
字典(映射)
| 如果你想... | 所以,你写... | Python调用... |
|---|---|---|
| 通过它的key来获得值 | x[key] |
x.__getitem__(key) |
| 通过它的key来设置一个值 | x[key] = value |
x.__setitem__(key, value) |
| 删除键值对 | del x[key] |
x.__delitem__(key) |
| 为丢失的key提供默认值 | x[nonexistent_key] |
x.__missing__(nonexistent_key) |
数字
| 如果你想... | 所以,你写... | Python调用... | |
|---|---|---|---|
| 加 | x + y |
x.__add__(y) |
|
| 减 | x - y |
x.__sub__(y) |
|
| 乘 | x * y |
x.__mul__(y) |
|
| 整除 | x / y |
x.__trueiv__(y) |
|
| 除 | x // y |
x.__floordiv__(v) |
|
| 取余 | x % y |
x.__mod__(y) |
|
| 整除与取余 | divmod(x, y) |
x.__divmod__(y) |
|
| 平方 | x ** y |
x.__pow__(y) |
|
| 左移 | x << y |
x.__lshift__(y) |
|
| 友移 | x >> y |
x.__rshift__(y) |
|
| 按位and运算 | x & y |
x.__and__(y) |
|
| 按位xor或运算 | x ^ y |
x.__xor__(y) |
|
| 按位or运算 | `x | y` | x.__or__(y) |
上述一组特殊方法采用第一种方法:给定x / y,它们提供了一种方法让x说"我知道如何用y整除自己".以下一组特殊方法解决了第二种方法:它们为y提供了一种方法来说"我知道如何成为分母,并将自己整除x".
| 如果你想... | 所以,你写... | Python调用... | |
|---|---|---|---|
| 加 | x + y |
x.__radd__(y) |
|
| 减 | x - y |
x.__rsub__(y) |
|
| 乘 | x * y |
x.__rmul__(y) |
|
| 整除 | x / y |
x.__rtrueiv__(y) |
|
| 除 | x // y |
x.__rfloordiv__(v) |
|
| 取余 | x % y |
x.__rmod__(y) |
|
| 整除与取余 | divmod(x, y) |
x.__rdivmod__(y) |
|
| 平方 | x ** y |
x.__rpow__(y) |
|
| 左移 | x << y |
x.__rlshift__(y) |
|
| 友移 | x >> y |
x.__rrshift__(y) |
|
| 按位and运算 | x & y |
x.__rand__(y) |
|
| 按位xor或运算 | x ^ y |
x.__rxor__(y) |
|
| 按位or运算 | `x | y` | x.__ror__(y) |
可是等等!还有更多!如果你正在进行"就地"操作,如x /= 3则可以定义更多特殊的方法.
| 如果你想... | 所以,你写... | Python调用... | |
|---|---|---|---|
| 加 | x + y |
x.__iadd__(y) |
|
| 减 | x - y |
x.__isub__(y) |
|
| 乘 | x * y |
x.__imul__(y) |
|
| 整除 | x / y |
x.__itrueiv__(y) |
|
| 除 | x // y |
x.__ifloordiv__(v) |
|
| 取余 | x % y |
x.__imod__(y) |
|
| 整除与取余 | divmod(x, y) |
x.__idivmod__(y) |
|
| 平方 | x ** y |
x.__ipow__(y) |
|
| 左移 | x << y |
x.__ilshift__(y) |
|
| 友移 | x >> y |
x.__irshift__(y) |
|
| 按位and运算 | x & y |
x.__iand__(y) |
|
| 按位xor或运算 | x ^ y |
x.__ixor__(y) |
|
| 按位or运算 | `x | y` | x.__ior__(y) |
还有一些"单个数"数学运算可以让你自己对类似数字的对象进行数学运算.
| 如果你想... | 所以,你写... | Python调用... |
|---|---|---|
| 负数 | -x |
x.__neg__() |
| 正数 | +x |
x.__pos__() |
| 绝对值 | abs(x) |
x.__abs__() |
| 逆 | ~x |
x.__invert__() |
| 复数 | complex(x) |
x.__complex__() |
| 整数 | int(x) |
x.__int__() |
| 浮点数 | float(x) |
x.__float__() |
| 四舍五入到最近的整数 | round(x) |
x.__round__() |
| 四舍五入到最近的n位数 | round(x, n) |
x.__round__(n) |
| 最小整数 | math.ceil(x) |
x.__ceil__() |
| 最大整数 | math.floor(x) |
x.__floor__() |
| 截断x到0的最接近的整数 | math.trunc(x) |
x.__trunc__() |
| 数字作为列表索引 | a_list[x] |
a_list[x.__index__()] |
比较
| 如果你想... | 所以,你写... | Python调用... |
|---|---|---|
| 等于 | x == y |
x.__eq__(y) |
| 不等于 | x != y |
x.__ne__(y) |
| 小于 | x < y |
x.__lt__(y) |
| 小于等于 | x <= y |
x.__le__(y) |
| 大于 | x > y |
x.__gt__(y) |
| 大于等于 | x >= y |
x.__ge__(y) |
| 布尔 | if x: |
x.__bool__() |
序列化
| 如果你想... | 所以,你写... | Python调用... |
|---|---|---|
| 对象副本 | copy.copy(x) |
x.__copy__() |
| 深拷贝 | copy.deepcopy(x) |
x.__deepcopy__() |
| 序列化一个对象 | pickle.dump(x, file) |
x.__getstate__() |
| 序列化一个对象 | pickle.dump(x, file) |
x.__reduce__() |
| 序列化一个对象 | pickle.dump(x, file, protocol_version) |
x.__reduce_ex__(protocol_version) |
| 取出恢复后的状态 | x = pickle.load(fp) |
x.__getnewargs__() |
| 取出恢复后的状态 | x = pickle.load(fp) |
x.__setstate__() |
with 语句
with块限定了运行时上下文;在执行with语句时,"进入"上下文,并在执行块中的最后一个语句后"退出"上下文.
| 如果你想... | 所以,你写... | Python调用... |
|---|---|---|
| 进入with语句块 | with x: |
x.__enter__() |
| 退出with语句块 | with x: |
x.__exit__(exc_type, exc_value, traceback) |
真正深奥的东西
| 如果你想... | 所以,你写... | Python调用... |
|---|---|---|
| 一个类的构造函数 | x = MyClass() |
x.__new__() |
| 一个类的析构函数 | del x |
x.__del__() |
| 只有一组特定的属性需要定义 | `` | x.__solts__() |
| hash码 | hash(x) |
x.__hash__() |
| 获得一个属性的值 | x.color |
type(x).__dict__['color'].__get__(x, type(x)) |
| 设置一个属性的值 | x.color = 'PapayaWhip' |
type(x).__dict__['color'].__set__(x, 'PapayaWhip') |
| 删除一个属性 | del x.color |
type(x).__dict__['color'].__del__(x) |
| 一个对象是否是你的一个类的实例 | isinstance(x, MyClass) |
MyClass.__instancecheck__(x) |
| 一个类是否是你的类的子类 | isinstance(C, MyClass) |
MyClass.__subclasscheck__(C) |
| 一个类是否是抽象基类的实例 | isinstance(C, MyABC) |
MyABC.__subclasshook__(C) |
1. Python 魔法方法的更多相关文章
- Python魔法方法总结及注意事项
1.何为魔法方法: Python中,一定要区分开函数和方法的含义: 1.函数:类外部定义的,跟类没有直接关系的:形式: def func(*argv): 2.方法:class内部定义的函数(对象的方法 ...
- python魔法方法:__getattr__,__setattr__,__getattribute__
python魔法方法:__getattr__,__setattr__,__getattribute__ 难得有时间看看书....静下心来好好的看了看Python..其实他真的没有自己最开始想的那么简单 ...
- python魔法方法大全
1.python魔法方法详解: python魔法方法是可以修改重载的,如果你的对象实现(重载)了这些方法中的某一个,那么这个方法就会在特殊的情况下被 Python 所调用,你可以定义自己想要的行为,而 ...
- python 魔法方法补充(__setattr__,__getattr__,__getattribute__)
python 魔法方法补充 1 getattribute (print(ob.name) -- obj.func())当访问对象的属性或者是方法的时候触发 class F(object): def _ ...
- with上下文管理 python魔法方法
with语法在Python里很常见, 主要的利好是使用代码更简洁. 常见的使用场景有: 1. 资源对象的获取与释放. 使用with可以简化try...finally ... 2. 在不修改函数代码的前 ...
- python 魔法方法诠释
什么是Python魔法方法 什么是魔法方法呢?它们在面向对象的Python的处处皆是.它们是一些可以让你对类添加"魔法"的特殊方法. 它们经常是两个下划线包围来命名的(比如 ini ...
- python 魔法方法
I am not a creator, I just a porter. Note: Everything is object in python. 对于Python来说一切都是对象,也就是函数的参数 ...
- python 魔法方法之:__getitem__ __setitem__ __delitem__
h2 { color: #fff; background-color: #7CCD7C; padding: 3px; margin: 10px 0px } h3 { color: #fff; back ...
- python 魔法方法(学习过程的笔记)
有小伙伴会问,什么是python的魔法方法,python的魔法方法有什么用呢, 它们在面向对象的Python的处处皆是.它们是一些可以让你对类添加"魔法"的特殊方法. 它们经常是两 ...
随机推荐
- C# Winform制作虚拟键盘,支持中文
原文:C# Winform制作虚拟键盘,支持中文 最近在做一个虚拟键盘功能,代替鼠标键盘操作,效果如下: 实现思路: 1 构建中文-拼音 数据库, ...
- WPF Layout 系统概述——Arrange
原文:WPF Layout 系统概述--Arrange Arrange过程概述 普通基类属性对Arrange过程的影响 我们知道Measure过程是在确定DesiredSize的大小,以便Arrang ...
- 细谈unity资源管理的设计
一.概要 本文主要说说Unity是如何管理的,基于何种方式,基于这种管理方式,又该如何规划资源管理,以及构建bundle,是后面需要详细讨论的. 二.Unity的资源管理方式 2.1 资源分类 uni ...
- iOS Widget简单使用
iOS的Widget类似Android的Notification设置flags为Notification.FLAG_ONGOING_EVENT后 OK,大约知道是什么意思了,现在可以开始码了 ...
- UWP 浏览本地图片及对图片的裁剪
原文:UWP 浏览本地图片及对图片的裁剪 1.前言 准备给我的校园助手客户端添加一个修改头像的功能,但是查了好多资料都没有找到裁剪图片的简单的方法,最后才找到这个使用Launcher调用系统组件的简单 ...
- Redis实现Timeline
上回写了[使用Redis实现关注关系][1],这次说说使用Redis实现Timeline. Timeline的实现一般有推模式.拉模式.推拉结合这几种. 推模式:某人发布内容之后推送给所有粉丝,空间换 ...
- 使用Newtonsoft.Json输出JSON
安装: Install-Package Newtonsoft.Json 代码: //序列化DataTable DataTable dt = new DataTable(); dt.Columns.Ad ...
- .NET Core2.1项目在Linux上使用验证码报Unable to load shared library 'gdiplus' or one of its dependencies
-- ::, 线程ID:[] 日志级别:ERROR 出错类:WebApp.HttpGlobalExceptionFilter property:[(null)] - 错误描述:System.TypeI ...
- storm和kafka的wordCount
这个是在window环境下面安装的kafka 下载pom依赖 <dependency> <groupId>org.apache.storm</groupId> &l ...
- einsum:爱因斯坦求和约定
在Tensorflow.Numpy和PyTorch中都提供了使用einsum的api,einsum是一种能够简洁表示点积.外积.转置.矩阵-向量乘法.矩阵-矩阵乘法等运算的领域特定语言.在Tensor ...