autodoc: base classes are shown with full name instead of respecting the import(AutoDoc:基类以全名显示,而不是尊重导入)
本文介绍了AutoDoc:基类以全名显示,而不是尊重导入的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我希望我能在这里为这个相当复杂的问题找到解决方案。
我使用狮身人面像和intersphinx来记录我的项目。
我有一个继承自mongoEng.Document的类。
当我使用sphinx-apidoc和sphinx-Build(通过sphinx-QuickStart自动生成的Makefile)构建sphinx文档时,对mongoEng.Document类的引用显示为mongoEng.Document.Document,这实际上是正确的完全限定名,但这是一个问题,因为在mongoEngine项目中,该类被标记为mongoEngine。Document,所以intersphinx根本没有链接。
有没有办法告诉Shinx在导入基类(在我的代码中,我从MongoEngine导入文档中)而不是它的完整模块路径时生成有关基类的信息?
以下代码:
from mongoengine import Document, EmbeddedDocumentListField
class MyDocument(Document):
""" my docstring """
它会生成如下所示的html:
class myproj.models.MyDocument(*args, **values) Bases:
mongoengine.document.Document <-- intersphinx does not find the link to external doc!
而不是
class myproj.models.MyDocument(*args, **values)
Bases: mongoengine.Document <-- here intersphinx will properly link
推荐答案
__module__属性保存在其中定义类的模块的名称。Document.__module__的值为"mongoEng.Document"。
该属性是可写的,因此解决方法是在代码中添加以下行:
Document.__module__ = "mongoengine"
这篇关于AutoDoc:基类以全名显示,而不是尊重导入的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
编程基础网
本文标题为:AutoDoc:基类以全名显示,而不是尊重导入
基础教程推荐
猜你喜欢
- 在 Celery 工作人员中捕获 Heroku SIGTERM 以优雅地关 2022-01-01
- pyserial - 可以从线程 a 写入串行端口,是否阻塞从线程 b 读取? 2022-01-01
- 用 Python 编写 Fortran 无格式文件 2022-01-01
- numpy float:比算术运算中内置的慢 10 倍? 2022-01-01
- Discord.py 缺少必需的参数 2022-01-01
- 将 x 轴刻度更改为自定义字符串 2022-01-01
- 与常规 dict 相比,Python manager.dict() 非常慢 2022-01-01
- 由Python将MP3转换为MIDI(类型错误:无法加载插件:mtg-Melodia:Melodia) 2022-01-01
- 尝试制作WhatsApp机器人 2022-01-01
- 使用生成器和迭代器时 Python 多循环失败 2022-01-01
