系统学习Python——装饰器:“私有“和“公有“属性案例-[验证函数的参数:针对位置参数的一个基本范围测试装饰器]

本文主要是介绍系统学习Python——装饰器:“私有“和“公有“属性案例-[验证函数的参数:针对位置参数的一个基本范围测试装饰器],希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

分类目录:《系统学习Python》总目录


让我们从基本的范围测试实现开始。为了简化步骤,起初我们将编写一个只对位置参数有效的装饰器,并且假设这些参数在每次调用中总是出现在相同的位置。位置参数不能通过关键字名称传递,并且我们在调用中不支持额外的**args关键字,因为这可能导致装饰器中的位置声明无效:

def rangetest(*argchecks):def onDecorator(func):if not __debug__:return funcelse:def onCall(*args):for (ix, low, high) in argchecks:if args[ix] < low or args[ix]  > high:errmsg = 'Argument %s not in %s-%s' % (ix, low, high)raise TypeError(errmsg)return func(*args)return onCallreturn onDecorator

算是老调重弹,这段代码略微修改了我们前面介绍的编程模式:我们使用装饰器参数、嵌套作用域来进行状态保持等等。

就像在前面的文章中学习到的,我们还使用了嵌套的def句以确保这个装饰器对简单函数和方法都有效。当用于类的方法时,oncall*args中的第一项接受主体类的实例,并且将其传递给最初的方法函数中的self;在这个例子中,范围测试中的参数数目从1开始,而不是从0开始。

注意这里的新情况,这段代码使用了__debug__内置变量一一滁非用·O优化命令行标志运行它(例如python -O main.py),否则都会将其设置为True。当__debug__False的时候,装饰器返回未修改的最初函数,以避免额外调用及其相关的性能损失。换言之当使用·0时,装饰器自动移除其扩增逻辑,而不会要求你在编辑器中移除装饰代码。第一次迭代解决方案使用如下:

@rangetest((1, 0, 120))
def personinfo(name, age):print('%s is %s years old.' % (name, age))@rangetest([0, 1, 12], [1, 1, 31], [2, 0, 2099])
def birthday(M, D, Y):print('birthday = {0}/{1}/{2}'.format(M, D, Y))class Person:def __init__(self, name, job, pay):self.job = jobself.pay = pay@rangetest([1, 0, 1])def giveRaise(self, percent):self.pay = int(self.pay * (1 + percent))

然后我们可以测试各种情况下的输入:

personinfo('Bob Smith', 45)

输出:

Bob Smith is 45 years old.

输入:


personinfo('Bob Smith', 150)

输出:

TypeError                                 Traceback (most recent call last)
Input In [17], in <cell line: 1>()
----> 1 personinfo('Bob Smith', 150)Input In [14], in rangetest.<locals>.onDecorator.<locals>.onCall(*args)8     if args[ix] < low or args[ix]  > high:9         errmsg = 'Argument %s not in %s-%s' % (ix, low, high)
---> 10         raise TypeError(errmsg)11 return func(*args)TypeError: Argument 1 not in 0-120

输入:

birthday(12, 31, 2000)

输出:

birthday = 12/31/2000

输入:

birthday(13, 31, 2000)

输出:

---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
Input In [19], in <cell line: 1>()
----> 1 birthday(13, 31, 2000)Input In [14], in rangetest.<locals>.onDecorator.<locals>.onCall(*args)8     if args[ix] < low or args[ix]  > high:9         errmsg = 'Argument %s not in %s-%s' % (ix, low, high)
---> 10         raise TypeError(errmsg)11 return func(*args)TypeError: Argument 0 not in 1-12

输入:

sue = Person('Sue Jones', 'dev', 100000)
sue.giveRaise(0.1)
print(sue.pay)

输出:

110000

输入:

sue.giveRaise(1.1)
print(sue.pay)

输出:

TypeError                                 Traceback (most recent call last)
Input In [23], in <cell line: 1>()
----> 1 sue.giveRaise(1.1)2 print(sue.pay)Input In [14], in rangetest.<locals>.onDecorator.<locals>.onCall(*args)8     if args[ix] < low or args[ix]  > high:9         errmsg = 'Argument %s not in %s-%s' % (ix, low, high)
---> 10         raise TypeError(errmsg)11 return func(*args)TypeError: Argument 1 not in 0-1

参考文献:
[1] Mark Lutz. Python学习手册[M]. 机械工业出版社, 2018.

这篇关于系统学习Python——装饰器:“私有“和“公有“属性案例-[验证函数的参数:针对位置参数的一个基本范围测试装饰器]的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、