当前位置: 首页 > news >正文

Python 一等函数(函数内省)

函数内省

除了 doc,函数对象还有很多属性。使用 dir 函数可以探知
factorial 具有下述属性:

>>> dir(factorial)
['__annotations__', '__call__', '__class__', '__closure__', '__code__',
'__defaults__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__',
'__format__', '__ge__', '__get__', '__getattribute__', '__globals__',
'__gt__', '__hash__', '__init__', '__kwdefaults__', '__le__', '__lt__',
'__module__', '__name__', '__ne__', '__new__', '__qualname__', '__reduce__',
'__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__',
'__subclasshook__']
>>>

其中大多数属性是 Python 对象共有的。本节讨论与把函数视作对象相关
的几个属性,先从__dict__ 开始。

与用户定义的常规类一样,函数使用__dict__ 属性存储赋予它的用户
属性。这相当于一种基本形式的注解。一般来说,为函数随意赋予属性
不是很常见的做法,但是 Django 框架这么做了。参见“The Django admin
site”文档(https://docs.djangoproject.com/en/1.10/ref/contrib/admin/)中对
short_description、boolean 和 allow_tags 属性的说明。这篇
Django 文档中举了下述示例,把 short_description 属性赋予一个方
法,Django 管理后台使用这个方法时,在记录列表中会出现指定的描述
文本:

def upper_case_name(obj):return ("%s %s" % (obj.first_name, obj.last_name)).upper()
upper_case_name.short_description = 'Customer name'

下面重点说明函数专有而用户定义的一般对象没有的属性。计算两个属
性集合的差集便能得到函数专有属性列表(见示例 5-9)。
示例 5-9 列出常规对象没有而函数有的属性

>>> class C: pass # ➊
>>> obj = C() # ➋
>>> def func(): pass # ➌
>>> sorted(set(dir(func)) - set(dir(obj))) # ➍
['__annotations__', '__call__', '__closure__', '__code__', '__defaults__',
'__get__', '__globals__', '__kwdefaults__', '__name__', '__qualname__']
>>>

➊ 创建一个空的用户定义的类。
➋ 创建一个实例。
➌ 创建一个空函数。
➍ 计算差集,然后排序,得到类的实例没有而函数有的属性列表。
表 5-1 对示例 5-9 中列出的属性做了简要说明。
表5-1:用户定义的函数的属性

image

image
后面几节会讨论__defaults__、code 和__annotations__ 属
性,IDE 和框架使用它们提取关于函数签名的信息。但是,为了深入了
解这些属性,我们要先探讨 Python 为声明函数形参和传入实参所提供的
强大句法。

http://www.xdnf.cn/news/116785.html

相关文章:

  • OpenCV 图形API(62)特征检测-----在图像中查找最显著的角点函数goodFeaturesToTrack()
  • 动态哈希映射深度指南:从基础到高阶实现与优化
  • windows部署ChatTTS对话场景的文本转语音大模型
  • 人工智能在个人能力提升方面的研究
  • DeepSeek是否采用了混合专家(MoE)架构?它如何提升模型效率?
  • 《Pinia 从入门到精通》Vue 3 官方状态管理 -- 插件扩展篇
  • 游戏开发核心技术全景解析——从引擎架构到网络安全防护体系
  • 架构-软件架构设计
  • 协作开发攻略:Git全面使用指南 — 第一部分 Git基础
  • 出现delete CR eslint错误
  • NVIDIA高级辅助驾驶安全报告解析
  • HTML、XHTML 和 XML区别
  • 网络安全 | F5 WAF 黑白名单配置实践指南
  • 【网工第6版】第5章 网络互联⑦
  • 【设计模式-4】深入理解设计模式:工厂模式详解
  • 自由学习记录(57)
  • Julia Notebook
  • React中createPortal 的详细用法
  • 问道数码兽 怀旧剧情回合手游源码搭建教程(反查重优化版)
  • 如何快速高效学习Python?
  • [密码学实战]在Linux中实现SDF密码设备接口
  • Python基础语法:字面量,注释,关键字,标识符,变量和引用,程序执行的3大流程
  • SIGGRAPH投稿相关官方指导
  • R-CNN,Fast-R-CNN-Faster-R-CNN个人笔记
  • Visual Studio C/C++编译器cl.exe的/source-charset与/execution-charset设置项
  • Linux平台实现低延迟的RTSP、RTMP播放
  • dirsearch 使用教程:详细指南与配置解析
  • Java 使用 RabbitMQ 消息处理(快速上手指南)
  • 考拉悠然:科技与匠心,以烟草虫情AI监测系统共筑品质未来
  • LeetCode 3040 相同分数的最大操作数目II