太好用!教你几招Python魔法方法的妙用
off999 2024-11-15 23:06 13 浏览 0 评论
专注Python、AI、大数据,请关注公众号七步编程!
Python是一种简单的编程语言,满足一个需求,可以有各种各样的实现方法。正是因为它可以通过各种串联满足很多复杂的逻辑,因此,对代码可读性关注度不高的开发者而言,会编写出很多复杂而令人难以理解的代码。
Python语法本身虽然简单,但是要想实现可读性高,让其他开发者能够轻松理解的代码却是一项需要长时间学习和加强的技能。
而在这众多技能中,魔法方法(Magic Methods)便是其中一个很棒的选择,它允许用户在定义类的时候能够使用内置运算符和关键字,让使用类的方法更加直观明了。
魔法方法
如果你已经使用了一段时间Python,那么一定了解或者接触过魔法方法。
魔法方法是一种以双下划线开头和结尾的一种特殊方法,在使用类的时候非常常见,例如,经常会用到的__init__。它的功能是作为构造函数,能够在类初始化时调用,你可以在初始化方法中定义一些初始化变量、初始化操作,当执行到类内部时,它会首先执行这些方法。
当然,魔法方法远不至于__init__,为了帮助大家理解Python魔法方法的价值,本文就以一个示例来开始本文的讲解。
下面通过实现一个名为TimePeriod的类,来看一下如何使用Python魔法方法使得代码更加清晰、可读性更高。
基础的TimePeriod类
下面TimePeriod主要实现2个方法:
- 时间的增加
- 时间的比较
基础的实现方法大多会是下面这样:
class TimePeriod:
def __init__(self, hours=0, minutes=0):
self.hours = hours
self.minutes = minutes
def add(self, other):
minutes = self.minutes + other.minutes
hours = self.hours + other.hours
if minutes >= 60:
minutes -= 60
hours += 1
return TimePeriod(hours, minutes)
def greater_than(self, other):
if self.hours > other.hours:
returnTrue
elif self.hours < other.hours:
returnFalse
elif self.minutes > other.minutes:
returnTrue
else:
returnFalse
实现add和greater_than两个方法,分别用于增加和对比时间大小。
或许,从这段代码中看不出有任何问题。接下来,我们使用这个类来看一下。
time_i_sleep = TimePeriod(9, 0)
time_i_work = TimePeriod(0, 30)
print(time_i_sleep.greater_than(time_i_work))
# True
这段代码在执行的时候没有任何问题,也不会报错。但是,如果你想要执行更为复杂的操作,例如,2个时间段加和再和另外2个时间段的加和进行对比,类似于A+B与C+D进行比较,如果使用上述这个类,对比会是这样的:
time_i_sleep.add(time_i_watch_netflix).greater_than(time_i_work.add(time_i_do_chores))
这样看上去是不是非常复杂?
即便是作为一名聪明的开发人员,把这段代码拆开执行,也会像下面这样复杂:
time_spent_unproductively = time_i_sleep.add(time_i_watch_netflix)
time_spent_productively = time_i_work.add(time_i_do_chores)
time_spent_unproductively.greater_than(time_spent_productively)
魔法方法实现方式
其实在Python中,很容易就可以实现上述功能,Python内置的有2个魔方方法__add__和__gt__分别对应于+和>运算。
现在,通过魔法方法来修改一下上面的类:
class TimePeriod:
def __init__(self, hours=0, minutes=0):
self.hours = hours
self.minutes = minutes
def __add__(self, other):
minutes = self.minutes + other.minutes
hours = self.hours + other.hours
if minutes >= 60:
minutes -= 60
hours += 1
return TimePeriod(hours, minutes)
def __gt__(self, other):
if self.hours > other.hours:
returnTrue
elif self.hours < other.hours:
returnFalse
elif self.minutes > other.minutes:
returnTrue
else:
returnFalse
现在,再来进行一下对比运算:
(time_i_sleep + time_i_watch_netflix) > (time_i_work + time_i_do_chores)
这样看起来是不是更加容易理解和阅读了?
除此之外,你还可以加入更多魔法方法,实现更为丰富的功能。
例如,你想比较2个时间是否相等,会用到==运算,这时候你可以使用魔法方法__eq__,具体实现如下:
def __eq__(self, other):
return self.hours == other.hours and self.minutes == other.minutes
Python魔法方法不止有算术运算和和比较运算,还有其他很多丰富的功能。例如,__str__,可以创建易于理解类的字符串。
def __str__(self):
returnf"{self.hours} hours, {self.minutes} minutes"
如果你需要,还可以通过__getitem__把类转化成字典:
def __getitem__(self, item):
if item == 'hours':
return self.hours
elif item == 'minutes':
return self.minutes
else:
raise KeyError()
这样,可以把很多字典的优质特性加入到类中,可以像访问字典一样去访问类的属性。
其他
除了上述提到的一些魔法方法,Python还有很多魔法方法值得使用。本文不再逐一举例,下面介绍一下一些常用方法的功能,需要的可以在以后编码中用一下。
- __new__:初始化类的实例时会调用__init__方法,而在实际创建实例时会更早地调用__new__方法。
- __call__:__call__方法允许我们的实例像方法或函数一样可调用。
- __len__:这允许你自定义Python内置len()函数。
- __repr__:这类似于__str__ 魔法方法,它允许你定义类的字符串表示形式。但是,区别在于__str__是针对最终用户的,它提供了一个更加用户友好的非正式字符串,而__repr__是针对开发人员的,并且可能包含有关类的内部状态的更复杂的信息。
- __setitem__:前面示例中我们已经看过__getitem__方法,它主要用于获取键值,而__setitem__则用于设置键值。
- __enter__和__exit__:这两种方法通常一起使用,可以将你的类用作上下文管理器,实现类似Python中with语句的功能。
总结
Python虽然语法方面简单,但是要成为一名优秀的Python开发人员,需要持续学习和积累,不断学习这些书籍和教程之外的知识,来提升你代码的规范性、可读性,这些小技能都是需要留意、必不可少的。
相关推荐
- PYTHON-简易计算器的元素介绍
-
[烟花]了解模板代码的组成importPySimpleGUIassg#1)导入库layout=[[],[],[]]#2)定义布局,确定行数window=sg.Window(...
- 如何使用Python编写一个简单的计算器程序
-
Python是一种简单易学的编程语言,非常适合初学者入门。本文将教您如何使用Python编写一个简单易用的计算器程序,帮助您快速进行基本的数学运算。无需任何高深的数学知识,只需跟随本文的步骤,即可轻松...
- 用Python打造一个简洁美观的桌面计算器
-
最近在学习PythonGUI编程,顺手用Tkinter实现了一个简易桌面计算器,功能虽然不复杂,但非常适合新手练手。如果你正在学习Python,不妨一起来看看这个项目吧!项目背景Tkint...
- 用Python制作一个带图形界面的计算器
-
大家好,今天我要带大家使用Python制作一个具有图形界面的计算器应用程序。这个项目不仅可以帮助你巩固Python编程基础,还可以让你初步体验图形化编程的乐趣。我们将使用Python的tkinter库...
- 用python怎么做最简单的桌面计算器
-
有网友问,用python怎么做一个最简单的桌面计算器。如果只强调简单,在本机运行,不考虑安全性和容错等的话,你能想到的最简单的方案是什么呢?我觉得用tkinter加eval就够简单的。现在开整。首先创...
- 说好的《Think Python 2e》更新呢!
-
编程派微信号:codingpy本周三脱更了,不过发现好多朋友在那天去访问《ThinkPython2e》的在线版,感觉有点对不住呢(实在是没抽出时间来更新)。不过还好本周六的更新可以实现,要不就放一...
- 构建AI系统(三):使用Python设置您的第一个MCP服务器
-
是时候动手实践了!在这一部分中,我们将设置开发环境并创建我们的第一个MCP服务器。如果您从未编写过代码,也不用担心-我们将一步一步来。我们要构建什么还记得第1部分中Maria的咖啡馆吗?我们正在创...
- 函数还是类?90%程序员都踩过的Python认知误区
-
那个深夜,你在调试代码,一行行检查变量类型。突然,一个TypeError错误蹦出来,你盯着那句"strobjectisnotcallable",咖啡杯在桌上留下了一圈深色...
- 《Think Python 2e》中译版更新啦!
-
【回复“python”,送你十本电子书】又到了周三,一周快过去一半了。小编按计划更新《ThinkPython2e》最新版中译。今天更新的是第五章:条件和递归。具体内容请点击阅读原文查看。其他章节的...
- Python mysql批量更新数据(兼容动态数据库字段、表名)
-
一、应用场景上篇文章我们学会了在pymysql事务中批量插入数据的复用代码,既然有了批量插入,那批量更新和批量删除的操作也少不了。二、解决思路为了解决批量删除和批量更新的问题,提出如下思路:所有更新语...
- Python Pandas 库:解锁 combine、update 和compare函数的强大功能
-
在Python的数据处理领域,Pandas库提供了丰富且实用的函数,帮助我们高效地处理和分析数据。今天,咱们就来深入探索Pandas库中四个功能独特的函数:combine、combine_fi...
- 记录Python3.7.4更新到Python.3.7.8
-
Python官网Python安装包下载下载文件名称运行后选择升级选项等待安装安装完毕打开IDLE使用Python...
- Python千叶网原图爬虫:界面化升级实践
-
该工具以Python爬虫技术为核心,实现千叶网原图的精准抓取,突破缩略图限制,直达高清资源。新增图形化界面(GUI)后,操作门槛大幅降低:-界面集成URL输入、存储路径选择、线程设置等核心功能,...
- __future__模块:Python语言版本演进的桥梁
-
摘要Python作为一门持续演进的编程语言,在版本迭代过程中不可避免地引入了破坏性变更。__future__模块作为Python兼容性管理的核心机制,为开发者提供了在旧版本中体验新特性的能力。本文深入...
- Python 集合隐藏技能:add 与 update 的致命区别,90% 开发者都踩过坑
-
add函数的使用场景及错误注意添加单一元素:正确示例:pythons={1,2}s.add(3)print(s)#{1,2,3}错误场景:试图添加可变对象(如列表)会报错(Pytho...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)