0

0

Python dir() 输出内容的真实含义

冷漠man

冷漠man

发布时间:2026-02-19 17:07:09

|

324人浏览过

|

来源于php中文网

原创

dir()返回的不是所有属性,而是对象当前命名空间中可枚举、非私有的名称列表,受__dir__方法控制,不保证完整性与顺序,且不验证属性是否真正可用。

python dir() 输出内容的真实含义

dir() 返回的到底是不是“所有属性”

不是。它返回的是对象当前命名空间中**可枚举的、非私有(不以双下划线开头或结尾)的名称列表**,但这个列表受 __dir__ 方法控制,且不包含动态生成但未被显式注册的属性。

常见错误现象:dir(obj) 看不到你刚用 obj.new_attr = 42 动态赋值的属性?那基本不可能——除非该对象是用 __slots__ 限制了属性集,或者重写了 __dir__ 并故意过滤掉了它。

  • 内置类型(如 liststr)的 dir() 结果包含大量继承自 object 的方法,比如 __eq____repr__,但不包括像 __dict__ 这类只在特定对象上存在的属性(例如实例有,类本身可能没有)
  • 如果类定义了 __dir__(self),Python 会直接调用它,忽略默认逻辑。很多封装库(如 pandas 的 Series)就靠这个隐藏内部字段
  • dir() 不保证顺序,也不保证完整性:C 扩展模块里用 PyMethodDef 注册的方法可能不会出现在 dir() 中,除非显式加入

为什么 dir(list) 和 dir([]) 输出不一样

因为一个是查 list 类本身,一个是查一个空 list 实例;它们的命名空间来源不同。

使用场景:调试时想确认某个方法是否属于实例还是类,或者怀疑自己调错了对象层级。

立即学习Python免费学习笔记(深入)”;

橙篇
橙篇

百度文库发布的一款综合性AI创作工具

下载
  • dir(list) 主要显示类属性、类方法(如 fromkeys)、继承来的特殊方法(__subclasses__
  • dir([]) 显示实例能访问的所有名称,包括实例字典里的键(如果有)、继承链上的方法、以及由 __dir__ 补充的内容
  • 性能影响很小,但反复对大型对象(如含数千个键的 dict 实例)调用 dir() 可能触发一次完整的属性扫描,不如直接查 obj.__dict__.keys()(如果存在)来得快

如何判断某个名字是不是“真能用”的属性

dir() 只是列名字,不验证有效性。一个名字在 dir() 里出现,不代表你能安全读取或调用它。

容易踩的坑:看到 __weakref__ 就以为可以赋值,结果抛出 AttributeError: __weakref__ is not writable;或者看到 _private_method 就当成公有接口用,其实它是约定俗成的内部实现。

  • 最可靠的方式是结合 hasattr(obj, 'name') + getattr(obj, 'name', None),而不是只信 dir()
  • 对方法,用 callable(getattr(obj, 'name', None)) 判断是否可调;对数据属性,注意有些是 property,读取可能触发异常(比如未初始化的 lazy 属性)
  • 某些框架(如 Django model 实例)的 dir() 会包含大量字段名,但这些字段只有在模型实例已从数据库加载后才真正可读——否则会触发 AttributeError 或延迟查询

替代 dir() 的更精准方案

当你要找的是“我到底能对这个对象干啥”,dir() 是起点,不是终点。

常见错误现象:在 Jupyter 里敲 obj. + Tab,结果补全列表和 dir(obj) 不一致——这是因为 IPython 的补全逻辑额外检查了 __all____dir__,甚至动态运行了部分描述符。

  • 查真实数据属性:obj.__dict__.keys()(仅限有 __dict__ 的实例)
  • 查类定义的属性(不含继承):[x for x in list.__dict__.keys() if not x.startswith('_')]
  • 查继承链上所有可调用方法:[x for x in dir(obj) if callable(getattr(obj, x, None))]
  • 看文档字符串最直接:help(obj.some_method) 比猜 dir() 输出靠谱得多

真正复杂的地方在于:Python 的属性访问是分层的——描述符协议、__getattribute____getattr__ 共同作用的结果。dir() 只反映静态命名空间快照,而实际访问行为可能完全跑在另一套逻辑里。别把它当权威,只当线索。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Python Web 框架 Django 深度开发
Python Web 框架 Django 深度开发

本专题系统讲解 Python Django 框架的核心功能与进阶开发技巧,包括 Django 项目结构、数据库模型与迁移、视图与模板渲染、表单与认证管理、RESTful API 开发、Django 中间件与缓存优化、部署与性能调优。通过实战案例,帮助学习者掌握 使用 Django 快速构建功能全面的 Web 应用与全栈开发能力。

94

2026.02.04

Python 时间序列分析与预测
Python 时间序列分析与预测

本专题专注讲解 Python 在时间序列数据处理与预测建模中的实战技巧,涵盖时间索引处理、周期性与趋势分解、平稳性检测、ARIMA/SARIMA 模型构建、预测误差评估,以及基于实际业务场景的时间序列项目实操,帮助学习者掌握从数据预处理到模型预测的完整时序分析能力。

75

2025.12.04

Python 数据清洗与预处理实战
Python 数据清洗与预处理实战

本专题系统讲解 Python 在数据清洗与预处理中的核心技术,包括使用 Pandas 进行缺失值处理、异常值检测、数据格式化、特征工程与数据转换,结合 NumPy 高效处理大规模数据。通过实战案例,帮助学习者掌握 如何处理混乱、不完整数据,为后续数据分析与机器学习模型训练打下坚实基础。

4

2026.01.31

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

820

2023.08.22

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

573

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

216

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1553

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

640

2023.11.24

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

660

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 4.4万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号