Проблемы с autodoc и явно указанными атрибутами экземпляра

Я написал класс 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 для атрибутов, сообщаемых как None, что sphinx не isntantiate класс, поэтому существует разница между атрибутом класса (как опора) и атрибутом экземпляра (как). Но как я могу ссылаться на атрибут экземпляра в документе?

На самом деле атрибуты экземпляра находятся, если они явно не запрашиваются в первом файле. Например, это будет работать:

.. autoclass:: aclass.Aclass
    :members:

Но это не

.. autoclass: aclass.Aclass
    :members: a

person Ger    schedule 12.07.2013    source источник
comment
Решение С.Лотта здесь обеспечивает дополнительную работу: manifest-in-init" title="как я могу сделать атрибуты объекта документа python sphinx объявленными только в init"> stackoverflow.com/questions/3959615/   -  person ecoe    schedule 11.01.2014


Ответы (1)


По этому поводу есть отчет об ошибке (созданный 30 марта 2012 г.; открыт 12 декабря 2015 г.): https://github.com/sphinx-doc/sphinx/issues/904.

  1. В этой фиксации была исправлена ​​проблема с явным списком :members:, содержащим атрибуты экземпляра. включено в Sphinx 1.2b1).

  2. Как упоминалось в комментарии (от Джона Уолтмана), существует недокументированная директива autoinstanceattribute.

    Использование .. autoinstanceattribute:: aclass.Aclass.a работает (проверено на Sphinx 1.1.3 и 1.2b1).

person mzjn    schedule 16.07.2013
comment
Похоже, autoinstanceattribute больше не работает: у меня есть WARNING: Unknown directive type "autoinstanceattribute". - person Gordon Bai; 26.05.2021
comment
@GordonBai: отчет об ошибке был закрыт 16 июля 2020 г. Работает ли autoattribute? - person mzjn; 26.05.2021
comment
Это был комментарий к проблеме, в котором упоминалось, что директива autoattribute вызывает AttributeError для атрибута экземпляра. Затем комментатор исправил проблему с помощью PR. Тем не менее, он по-прежнему поднимает AttributeError в моем тесте. Я использую Sphinx 4.0.2. - person Gordon Bai; 26.05.2021
comment
@GordonBai: autoinstanceattribute больше не работает, но autoattribute должно работать в Sphinx 4.1.0. См. github.com/sphinx-doc/sphinx/issues/9283. - person mzjn; 12.07.2021
comment
@mjzn Спасибо! Да, я знаю об этой проблеме, поскольку она открыта мной :) - person Gordon Bai; 13.07.2021