您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

restructuredText,docstring和python交互式shell

5b51 2022/1/14 8:21:20 python 字数 2716 阅读 481 来源 www.jb51.cc/python

我使用reStructuredText来记录我的代码,以便通过epydoc获得不错的离线HTML页面.结果很棒.唯一的缺点是当我使用Python交互式shell时,help()函数不解析文档字符串中的reST元数据,而是显示整个事物.有没有办法让help()对文档字符串进行一些最小的解析?我不希望渲染斜体字体或超链接,但至少进行一些最小的清理以提高可读性.最

概述

我使用reStructuredText来记录我的代码,以便通过epydoc获得不错的离线HTML页面.

结果很棒.唯一的缺点是当我使用Python交互式shell时,help()函数不解析文档字符串中的reST元数据,而是显示整个事物.

有没有办法让help()对文档字符串进行一些最小的解析?

我不希望渲染斜体字体或超链接,但至少进行一些最小的清理以提高可读性.

然后在sitecustomize.py文件添加所需的任何自定义项.

您可以通过以下两种方式处理:

如果要更改help()函数本身的(明显)行为,请将help函数包装在装饰器中,如:

def help_wrapper(func):
    def inner(*args):
        results = func(*args)
        return your_cleanup_function_here(results)
help = help_wrapper(help)

我个人更喜欢稍微不同的解决方案,因为没有人知道你的清理功能将如何帮助输出不是用RestructuredText编写的.

所以我只想创建一个包装函数

def my_help(*args):
    return your_cleanup_function_here(help(*args))

这样,如果需要,您仍然可以访问原始的help()函数.

CAVEAT:在sitecustomize.py中执行操作时要小心,因为无论你在这里做什么都可能会影响整个解释器会话(以及每个解释器会话),这有时会导致意想不到的后果.

总结

以上是编程之家为你收集整理的restructuredText,docstring和python交互式shell全部内容,希望文章能够帮你解决restructuredText,docstring和python交互式shell所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶