Python魔法方法使用详解及__getitem__、__len__使用举例

2024-02-17 09:18

本文主要是介绍Python魔法方法使用详解及__getitem__、__len__使用举例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.什么是魔法方法

        Python中魔法方法以__(双下划线)开头,以__(双下划线)结尾,当python解释器碰到特殊句法时会使用魔法方法去进行一些基本的对象操作。例如对一个可索引对象obj,进行obj[key]时,解释器会调用obj.__ getitem__(key)方法。
        魔法方法又叫特殊方法/双下方法。

2.魔法方法的使用

        例:当我们使用len

        明确一点:魔法方法的存在是为了给解释器调用,对于我们而言,不存在obj.__ len__()这种写法,应使用len(obj)。

        如果obj是我们自定义的类对象,且我们给这个类重写了__len__方法,那么当进行len(obj)时,python会自动调用我们重写的__len__方法

        如果obj是内置类型对象,如list、str、bytearry等,执行len(obj)时,调用内置的__ len__方法会直接返回PyVarObject内的ob_size属性

3.以__getitem__、__len__方法举例使用魔法方法

自定义一个类,类中重写__getitem__、__len__方法

import collections
person=collections.namedtuple('persion',['name','age'])
people = ['bob', 'Alice', 'John']
age_coll = ['13', '17', '42']
class magic(object):def __init__(self):self._person=[person(name,age) for name in people for age  in age_coll]def __len__(self):return len(self._person)def __getitem__(self, item):return self._person[item]
mag=magic()
print(len(mag))
print(mag[2])
#控制台输出:
#9
#persion(name='bob', age='42')

注意一点

当我们对魔法方法进行重写时,按理说我们实现的功能应当还是原方法的功能,但此时解释器只听我们的(调用我们写的重写的魔法方法)

那么,我们是可以搞破坏的:
将上述__getitem__写成这样:

    def __getitem__(self, item):return 'i am sabotaging'

执行

print(mag[2])
print(mag[3])

结果全为 i am sabotaging
当我们对魔法方法重写时,完全可以随意发挥(最好不要这样,玩玩还是可以的)

这篇关于Python魔法方法使用详解及__getitem__、__len__使用举例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/717340

相关文章

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

Redis中Stream详解及应用小结

《Redis中Stream详解及应用小结》RedisStreams是Redis5.0引入的新功能,提供了一种类似于传统消息队列的机制,但具有更高的灵活性和可扩展性,本文给大家介绍Redis中Strea... 目录1. Redis Stream 概述2. Redis Stream 的基本操作2.1. XADD

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

JAVA中安装多个JDK的方法

《JAVA中安装多个JDK的方法》文章介绍了在Windows系统上安装多个JDK版本的方法,包括下载、安装路径修改、环境变量配置(JAVA_HOME和Path),并说明如何通过调整JAVA_HOME在... 首先去oracle官网下载好两个版本不同的jdk(需要登录Oracle账号,没有可以免费注册)下载完

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定