我写了一个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:
一切正常,a
,prop
和square
出现在文档中。
但如果我试图分别记录属性和方法,那么sphinx说它不能找到属性a但它适用于道具。
.. 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没有实现类,因此class属性(作为prop)和实例属性(作为a)之间存在差异。但是如何在doc中引用实例属性?
实际上,如果未在第一个文件中明确询问实例属性,则会找到它们。例如,这将起作用:
.. autoclass:: aclass.Aclass
:members:
但这不是
.. autoclass: aclass.Aclass
:members: a
答案 0 :(得分:4)
有关于此的错误报告(创建于2012-03-30;仍在2015-12-12开放):https://github.com/sphinx-doc/sphinx/issues/904。
this commit(包含在Sphinx 1.2b1中)修复了包含实例属性的显式:members:
列表的问题。
正如评论中提到的(来自Jon Waltman),有一个未记录的autoinstanceattribute
指令。
使用.. autoinstanceattribute:: aclass.Aclass.a
确实有效(使用Sphinx 1.1.3和1.2b1进行测试)。