【发布时间】:2017-07-18 18:50:46
【问题描述】:
是否有一些自省方法可以可靠地获取对象实例的底层数据结构,不受任何自定义的影响?
在 Python 3 中,对象的低级实现可能会被深深地掩盖:可以自定义属性查找,甚至 __dict__ 和 __slots__ 属性也可能无法提供完整的图片,因为它们是可写的。 dir() 明确表示显示“有趣”属性而不是实际属性,甚至 inspect 模块似乎也没有提供这样的功能。
不是重复的。此问题已被标记为与Is there a built-in function to print all the current properties and values of an object? 重复。然而,另一个问题只讨论了自省类的标准方法,这里明确列出了在较低级别上不可靠。
作为示例考虑以下带有故意隐藏类的脚本。
import inspect
actual_members = None # <- For showing the actual contents later.
class ObscuredClass:
def __init__(self):
global actual_members
actual_members = dict()
self.__dict__ = actual_members
self.actual_field = "actual_value"
def __getattribute__(self, name):
if name == "__dict__":
return { "fake_field": "fake value - shown in __dict__" }
else:
return "fake_value - shown in inspect.getmembers()"
obj = ObscuredClass()
print(f"{actual_members = }")
print(f"{dir(obj) = }")
print(f"{obj.__dict__ = }")
print(f"{inspect.getmembers(obj) = }")
产生输出
actual_members = {'actual_field': 'actual_value'}
dir(obj) = ['fake_field']
obj.__dict__ = {'fake_field': 'fake value - shown in __dict__'}
inspect.getmembers(obj) = [('fake_field', 'fake_value - shown in inspect.getmembers()')]
【问题讨论】:
-
“标准”?甚至
inspect.get_members也不起作用? -
@user202729 我添加了一个示例来演示。甚至
inspect.get_members也依赖于对象而不是故意隐藏其内部。 -
想法:类似于
object.__getattribute__的东西可以按照stackoverflow.com/questions/371753/… 中的建议使用。当然它不适用于用 C 实现的对象。(话虽如此,尽管有很多 Python 类覆盖了__getattr__,但我没有看到太多覆盖__getattributes__) -
@user202729 这似乎有效。
-
您可能希望将其作为答案发布,而不是将其编辑到问题中。
标签: python python-3.x introspection