sphinxautodoc
拡張機能を使用してドキュメントを作成する場合、(クラス自体ではなく) クラス インスタンスを関数のようにドキュメント化するにはどうすればよいですか? クラスには__call__
メソッドが定義されています。
質問する
341 次
2 に答える
1
Sphinx 拡張機能を使用して問題を解決することができます。私にとっては、以下で十分でした:
で
conf.py
:- に適切なパスを追加
sys.path
しますconf.py
- リスト
sphinx.ext.autodoc
内の新しいモジュール名に置き換えますextensions
- に適切なパスを追加
新しいモジュールで:
- 輸入
sphinx.ext.autodoc
- のサブクラスを作成する
.autodoc.FunctionDocumenter
- 呼び出してから呼び出す
setup(app)
関数を作成する.autodoc.setup()
app.add_autodocumenter(SubclassName)
- 輸入
これは関数のドキュメンタを置き換えるため、それらに役立つようにする必要があることに注意してください。一意のobjtype
文字列を値としてクラス定数を定義することで問題を回避することは可能ですが、これにはそれ以上の作業が必要になります。通常の機能を気にする方が簡単です。
誰かが興味を持っているなら、コードはここにあります。
于 2013-03-17T16:44:43.507 に答える
0
具体的にはよくわかりませんautodoc
が、これを試すことができます:
class MyClass(object):
...
def __call__(self):
...
c = MyClass()
"""
this is a function-like object.
"""
c2 = MyClass()
"""
this is another function-like object.
"""
またはこれ:
#: this is a function-like object.
c = MyClass()
于 2013-03-16T20:52:30.993 に答える