gpt4 book ai didi

python - autodoc 和明确指定的实例属性的问题

转载 作者:太空狗 更新时间:2023-10-30 03:03:55 24 4
gpt4 key购买 nike

我写了一个 python 类,并用 sphinx 制作了文档。例如,类看起来像:

class Aclass(object):
""" my class """

def __init__(self):
""" constructor """

self.a = None
""" doc for attribute a """

self._prop = None

def _get_prop(self):
""" getter prop """
return self._prop

def _set_prop(self, val):
""" setter prop """
self._prop = val

prop = property(_get_prop, _set_prop)
""" a property """

def square(self):
""" return square of a """
return self.a**2

现在,为了做文档,我在第一个文件中写了:

.. autoclass:: aclass.Aclass
:members:

一切正常,apropsquare 出现在文档中。

enter image description here

但是如果我尝试分别记录属性和方法,sphinx 会说它找不到属性 a 但它适用于 prop。

.. autoattribute:: aclass.Aclass.prop

.. autoattribute:: aclass.Aclass.a

错误信息是:

Traceback (most recent call last):                                                                                
File "/usr/lib/python2.7/dist-packages/sphinx/ext/autodoc.py", line 326, in import_object
obj = self.get_attr(obj, part)
File "/usr/lib/python2.7/dist-packages/sphinx/ext/autodoc.py", line 232, in get_attr
return safe_getattr(obj, name, *defargs)
File "/usr/lib/python2.7/dist-packages/sphinx/util/inspect.py", line 70, in safe_getattr
raise AttributeError(name)
AttributeError: a

/home/gvallver/dev/sphinx/doc/source/index.rst:17: WARNING: autodoc can't import/find attribute 'aclass.Aclass.a', it reported error: "a", please check your spelling and sys.path

我在某处读过Sphinx values for attributes reported as None sphinx 不实例化类,因此类属性(作为 prop)和实例属性(作为 a)之间存在差异。但是如何在文档中引用实例属性?

实际上,如果第一个文件中没有明确询问实例属性,就会找到实例属性。例如,这将起作用:

.. autoclass:: aclass.Aclass
:members:

但这不

.. autoclass: aclass.Aclass
:members: a

最佳答案

有一个关于此的错误报告(创建于 2012 年 3 月 30 日;仍然开放于 2015 年 12 月 12 日):https://github.com/sphinx-doc/sphinx/issues/904 .

  1. 包含实例属性的显式 :members: 列表的问题已在 this commit 中修复(包含在 Sphinx 1.2b1 中)。

  2. 正如评论中提到的(来自 Jon Waltman),有一个未记录的 autoinstanceattribute 指令。

    使用 .. autoinstanceattribute::aclass.Aclass.a 确实有效(使用 Sphinx 1.1.3 和 1.2b1 测试)。

关于python - autodoc 和明确指定的实例属性的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17610807/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com