有没有办法让 pydoc 的 writedocs() 函数为包创建子目录?例如,假设我有以下模块要记录:
foo.py
dir/bar.py
dir/__init__.py
当我运行 pydoc.writedocs() 时,我得到以下文件:
foo.html
dir.bar.html
我想得到:
foo.html
dir/bar.html
有没有办法做到这一点?
pydoc.writedocs
只是循环调用writedoc
,它被记录(并实现)以“在当前目录中写入文件”。我能看到的唯一出路是制作一个修改版本并将其强制(即,叹气,猴子补丁)进入模块,或者猴子补丁它的一些关键方面,即打开'open'以编写它被问到的HTML文件打开。具体来说,在您的代码中,您可以执行以下操作:
import pydoc
def monkey_open(name, option):
if option == 'w' and name.endswith('.html'):
name_pieces = name.split('.')
name_pieces[-2:] = '.'.join(name_pieces[-2:])
name = '/'.join(name_pieces)
return open(name, option)
pydoc.open = monkey_open
不是一个优雅或极其强大的解决方案,但“需要必须”...... pydoc 只是不是为了让你做你想做的事而设计的,所以这件事需要“硬塞进去”一点。