Python教程:你一定要知道的26个Python魔术方法(快记下来)

简介: Python中的魔术方法是指以双下划线 __ 开头和结尾的特殊方法,也被称为特殊方法或魔术方法。这些方法在类中具有特殊的用途,它们可以让你自定义类的行为,使得你的对象可以像内置类型一样工作。

 Python中的魔术方法是指以双下划线 __ 开头和结尾的特殊方法,也被称为特殊方法或魔术方法。这些方法在类中具有特殊的用途,它们可以让你自定义类的行为,使得你的对象可以像内置类型一样工作。这些方法由解释器调用,而不是你直接调用它们。例如,当你使用 + 运算符时,实际上是调用了对象的 __add__ 方法。这些方法允许你重载运算符、改变对象的构造和初始化行为、自定义属性访问等等。使用魔术方法可以使你的代码更具表现力、可读性和灵活性。

Python 3.8.6中的一些常见魔术方法包括:

  • __init__: 对象初始化方法,在创建对象时调用。
  • __repr__: 返回对象的“官方”字符串表示形式。
  • __str__: 返回对象的“非正式”或友好字符串表示形式。
  • __len__: 返回对象的长度。
  • __getitem__: 获取对象中指定键的值。
  • __setitem__: 设置对象中指定键的值。
  • __delitem__: 删除对象中指定键的值。
  • __iter__: 返回一个迭代器对象。
  • __contains__: 检查对象是否包含指定的元素。
  • __call__: 实例对象作为函数调用时调用。
  • __eq__: 定义对象的相等性。
  • __lt__, __le__, __gt__, __ge__: 定义对象的比较行为。
  • __add__, __sub__, __mul__, __truediv__, __floordiv__, __mod__: 定义对象的算术运算。
  • __getattr__, __setattr__, __delattr__: 处理对象属性的获取、设置和删除。
  • __enter__, __exit__: 定义在使用 with 语句时对象的上下文管理行为。

以下是每个魔术方法的详细解释和示例代码:

__init__

初始化方法,在创建对象时调用。通常用于初始化对象的属性。

class MyClass:
    def __init__(self, x):
        self.x = x
obj = MyClass(5)
print(obj.x)  # 输出: 5

image.gif

__repr__

返回对象的“官方”字符串表示形式。通常用于开发者。

class MyClass:
    def __repr__(self):
        return 'MyClass()'
obj = MyClass()
print(repr(obj))  # 输出: MyClass()

image.gif

__str__

返回对象的“非正式”或友好字符串表示形式。通常用于用户。

class MyClass:
    def __str__(self):
        return 'MyClass instance'
obj = MyClass()
print(str(obj))  # 输出: MyClass instance

image.gif

__len__

返回对象的长度。

class MyList:
    def __init__(self, data):
        self.data = data
    def __len__(self):
        return len(self.data)
my_list = MyList([1, 2, 3, 4, 5])
print(len(my_list))  # 输出: 5

image.gif

__getitem__

获取对象中指定键的值。

class MyDict:
    def __init__(self, data):
        self.data = data
    def __getitem__(self, key):
        return self.data[key]
my_dict = MyDict({'a': 1, 'b': 2})
print(my_dict['a'])  # 输出: 1

image.gif

__setitem__

设置对象中指定键的值。

class MyDict:
    def __init__(self):
        self.data = {}
    def __setitem__(self, key, value):
        self.data[key] = value
my_dict = MyDict()
my_dict['a'] = 1
print(my_dict['a'])  # 输出: 1

image.gif

__delitem__

删除对象中指定键的值。

class MyDict:
    def __init__(self):
        self.data = {'a': 1, 'b': 2}
    def __delitem__(self, key):
        del self.data[key]
my_dict = MyDict()
del my_dict['a']
print(my_dict.data)  # 输出: {'b': 2}

image.gif

__iter__

返回一个迭代器对象。

class MyIterable:
    def __iter__(self):
        return iter([1, 2, 3, 4, 5])
obj = MyIterable()
for item in obj:
    print(item)  # 输出: 1 2 3 4 5

image.gif

__contains__

检查对象是否包含指定的元素。

class MyList:
    def __init__(self, data):
        self.data = data
    def __contains__(self, item):
        return item in self.data
my_list = MyList([1, 2, 3, 4, 5])
print(3 in my_list)  # 输出: True

image.gif

__call__

实例对象作为函数调用时调用。

class MyCallable:
    def __call__(self, x):
        return x * 2
obj = MyCallable()
print(obj(5))  # 输出: 10

image.gif

__eq__

定义对象的相等性。

class Point:
    def __init__(self, x, y):
        self.x = x
        self.y = y
    def __eq__(self, other):
        return self.x == other.x and self.y == other.y
p1 = Point(1, 2)
p2 = Point(1, 2)
print(p1 == p2)  # 输出: True

image.gif

__lt__, __le__, __gt__, __ge__

定义对象的比较行为。

class Point:
    def __init__(self, x, y):
        self.x = x
        self.y = y
    def __lt__(self, other):
        return self.x < other.x and self.y < other.y
p1 = Point(1, 2)
p2 = Point(2, 3)
print(p1 < p2)  # 输出: True

image.gif

__add__, __sub__, __mul__, __truediv__, __floordiv__, __mod__

定义对象的算术运算。

class MyNumber:
    def __init__(self, value):
        self.value = value
    def __add__(self, other):
        return self.value + other.value
a = MyNumber(5)
b = MyNumber(3)
print(a + b)  # 输出: 8

image.gif

__getattr__, __setattr__, __delattr__

处理对象属性的获取、设置和删除。

class MyObject:
    def __init__(self):
        self.data = {}
    def __getattr__(self, name):
        return self.data.get(name)
    def __setattr__(self, name, value):
        self.data[name] = value
    def __delattr__(self, name):
        del self.data[name]
obj = MyObject()
obj.name = 'Alice'
print(obj.name)  # 输出: Alice

image.gif

__enter__, __exit__

定义在使用 with 语句时对象的上下文管理行为。

class MyResource:
    def __enter__(self):
        print("Entering context")
        return self
    def __exit__(self, exc_type, exc_value, traceback):
        print("Exiting context")
with MyResource() as res:
    print("Doing something inside the context")

image.gif


目录
相关文章
|
8天前
|
数据采集 存储 JSON
Python网络爬虫教程概览
【6月更文挑战第21天】Python网络爬虫教程概览:安装requests和BeautifulSoup库抓取网页;使用HTTP GET请求获取HTML,解析标题;利用CSS选择器提取数据;处理异步内容可选Selenium;遵循爬虫策略,处理异常,尊重法律与网站规定。
17 1
|
2天前
|
Shell Python
Python教程:return和yield的区别
Python教程:return和yield的区别
6 0
Python教程:return和yield的区别
|
4天前
|
数据采集 存储 数据处理
使用Python获取1688商品详情的教程
使用Python爬取1688商品详情,涉及requests库抓取页面、BeautifulSoup解析HTML,安装必要库如requests、beautifulsoup4、pandas和lxml。通过get_page发送请求,BeautifulSoup解析提取如标题、价格等信息。数据处理后可使用pandas保存至CSV。注意遵守法律法规和网站政策,避免频繁请求。[代码片段及更多详情见链接
|
10天前
|
设计模式 测试技术 Python
Python教程:一文了解PageObject模式
PageObject 模式通常用于 Web 应用程序的 UI 自动化测试,尤其是在使用 Selenium、Appium 、Airtest等工具进行测试时非常有效。但是,它并不局限于特定类型的应用或工具,而是一种通用的设计模式,可以用于任何需要进行 UI 自动化测试的场景。
24 5
|
10天前
|
存储 数据安全/隐私保护 计算机视觉
Python教程:一文了解从Bytes到Bits的数据转换
在Python编程中,处理数据时经常需要在字节(bytes)和位(bits)之间进行转换。这种转换在网络通信、数据加密、图像处理等领域尤为常见。本文将详细介绍如何在Python中进行字节与位之间的转换,并提供一个实用的功能:如何在指定的位位置替换位数据。
21 4
|
10天前
|
存储 Python
Python教程:深入理解Python中的命名空间和作用域
在 Python 编程中,理解命名空间(Namespace)和作用域(Scope)是至关重要的。它们决定了变量和函数的可见性和访问性,并直接影响代码的结构和行为。本文将深入探讨 Python 3 中命名空间和作用域的概念、规则以及相关的高级主题。
24 4
|
10天前
|
Python
Python教程:一文了解Python的深拷贝与浅拷贝
理解 Python 中的深拷贝(deep copy)和浅拷贝(shallow copy)是非常重要的,特别是在处理嵌套结构的数据时。让我们深入探讨这两个概念,并通过代码示例进行说明。
19 4
|
10天前
|
算法 Java Python
Python教程:深入了解Python垃圾回收机制
在Python中,垃圾回收(Garbage Collection)是一种自动管理内存的机制,它可以自动识别和清理不再使用的对象,释放它们占用的内存空间,以提高内存利用率和程序性能。
16 3
|
10天前
|
搜索推荐 算法 Python
Python教程:使用Python实现冒泡排序和快速排序
排序算法根据其实现原理和效率可以分为多种类型,包括冒泡排序、选择排序、插入排序、归并排序、快速排序等。这些算法在不同的场景下具有不同的优劣势,需要根据实际需求选择合适的算法。
25 3
|
8天前
|
存储 JSON 数据格式
Python基础语法汇总【保姆级小白教程】
我将 Python语法分为14个章节,从第一章Python基础概念到第14章模块&异常处理,本篇文章将逐一为大家讲述.
40 0
Python基础语法汇总【保姆级小白教程】