[英]Sphinx: Link to a method of a class in another module in Python docstring
我想添加一个模块(比如在一个链接到一个类的方法module_2.py
在另一模块(比如另一种方法) module_1.py
)。 我希望链接在 Sphinx 中工作。
假设:
模块_1.py
class ABC:
def foo(self):
"""
See docstring of module_2.py bar():<link to bar() in module_2.py>
"""
print("foo")
模块_2.py
class XYZ:
def bar(self):
"""
This function prints hello.
"""
print("hello")
你可以写:
class ABC:
def foo(self):
"""
See docstring of :py:meth:`bar() <XYZ.bar>` in :py:mod:`module_2`.
"""
print("foo")
显示的标记使用角色链接到文档元素。 如果 Python 是文档的默认域,则:py
可以省略。 角色meth
链接到方法名称。 可以使用带点的名称。 同样, mod
链接到模块名称。 角色的内容写成ween ``
。 内容(逻辑链接名称可以有不同的视觉内容。因此逻辑链接名称写在<>
。例如: :role:`text <logical name>`
。
更多信息: http : //www.sphinx-doc.org/en/stable/domains.html#role-py : meth
要真正获得超链接,您的方法引用需要包含完整路径。 创建任何链接的最简单方法是使用:obj:
交叉引用:
"""See docstring of :obj:`path.to.module_2.XYZ.bar`."""
请参阅
path.to.module_2.XYZ.bar
文档字符串。
"""See docstring of :obj:`~path.to.module_2.XYZ.bar`."""
请参阅
bar
文档字符串。
或者像这样指定自定义文本:
"""See docstring of :obj:`XYZ.bar <path.to.module_2.XYZ.bar>`."""
请参阅
XYZ.bar
文档字符串。
这可能是对读者最友好的解决方案。
为了完整:obj:
,请注意:obj:
是一个通用的无类型引用,但 Sphinx 提供了其他几种具有某些特定行为的交叉引用类别。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.