检查类是否为Python中的数据类

Or *_*r B 2 python python-3.x python-dataclasses

如何检查dataclassPython中的类?

我发现可以检查__dataclass_fields____dataclass_params__属性的存在,但是我很想找到一种更优雅的方法。

我希望使用类似inspect.isclass函数的东西。例如inspect.isdataclass,也许像。

Python有这样的东西吗?

谢谢。

imp*_*ren 7

文件

import dataclasses
dataclasses.is_dataclass(something)
Run Code Online (Sandbox Code Playgroud)

正如@Arne内部提到的那样,它只是检查hasattr(something, '__dataclass_fields__'),但我建议不要依赖它:

  • 它不是公共API:在文档的任何地方都没有提及。
  • 这是一个实现细节,因此不能保证可以在其他python实现中使用。但是除此之外cPython似乎还没有任何东西支持Python3.7。至少Jython,IronPython和PyPy不支持它。

一切包括数据类类型和数据类的实例检查之间的差异是的文档is_dataclass方法

  • 请注意,所有`is_dataclass`在幕后所做的都是[检查`__dataclass_fields__`](https://github.com/python/cpython/blob/0a834c18cdafa5447d4436878e64aa7a4e4dc817/Lib/dataclasses.py#L1012-L1020)。 (3认同)

ama*_*anb 5

扩展上述答案,以下说明了 的用法is_dataclass()

请记住:传递给的参数is_dataclass()可以是数据类或数据类的实例,以True从方法调用中返回。

In [1]: from dataclasses import dataclass

In [2]: @dataclass
   ...: class Bio:
   ...:     name: str
   ...:     age: int
   ...:     height: float
   ...:

In [3]: from dataclasses import is_dataclass

In [4]: is_dataclass(Bio)
Out[4]: True

In [5]: b = Bio('John', 25, 6.5)

In [6]: is_dataclass(b)
Out[6]: True
Run Code Online (Sandbox Code Playgroud)

要检查是否b是数据类的实例而不是数据类本身:

In [7]: is_dataclass(b) and not isinstance(b, type)
Out[7]: True
Run Code Online (Sandbox Code Playgroud)

Bio是一个数据类,因此以下表达式的计算结果为False

In [8]: is_dataclass(Bio) and not isinstance(Bio, type)
Out[8]: False
Run Code Online (Sandbox Code Playgroud)

让我们检查一下常规课程:

In [9]: class Car:
   ...:     def __init__(self, name, color):
   ...:         self.name = name
   ...:         self.color = color
   ...:
Run Code Online (Sandbox Code Playgroud)

我们知道Car不是一个数据类:

In [10]: is_dataclass(Car)
Out[10]: False

In [11]: c = Car('Mustang', 'Blue')
Run Code Online (Sandbox Code Playgroud)

的实例都不Car是数据类实例:

In [12]: is_dataclass(c)
Out[12]: False
Run Code Online (Sandbox Code Playgroud)