不幸的是,这个模块需要在包中有时需要作为脚本运行。知道我怎么做吗实现这一目标?
这样的布局很常见。。。
main.py
mypackage/
__init__.py
mymodule.py
myothermodule.py
…有一个mymodule.py像这样。。。
#!/usr/bin/env python3
# Exported function
def as_int(a):
return int(a)
# Test function for module
def _test():
assert as_int('1') == 1
if __name__ == '__main__':
_test()
…一个肌肉热模块。。。
#!/usr/bin/env python3
from .mymodule import as_int
# Exported function
def add(a, b):
return as_int(a) + as_int(b)
# Test function for module
def _test():
assert add('1', '1') == 2
if __name__ == '__main__':
_test()
…还有一个像这样的男人。。。
#!/usr/bin/env python3
from mypackage.myothermodule import add
def main():
print(add('1', '1'))
if __name__ == '__main__':
main()
…当您运行main.py或mypackage/mymodule.py时,它工作得很好,但由于相对导入,mypackage/myothermodule.py失败。。。
from .mymodule import as_int
你应该用的方式是。。。
python3 -m mypackage.myothermodule
……但它有些冗长,与#/usr/bin/env python3。
对于这种情况,最简单的解决方法是避免使用相对导入,而只使用。。。
from mymodule import as_int
…虽然,如果它不是唯一的,或者您的包结构更复杂,您需要在PYTHONPATH中包含包含您的包目录的目录,并这样做。。。
from mypackage.mymodule import as_int
…或者如果你想让它“开箱即用”,你可以先用这个。。。
import sys
import os
SCRIPT_DIR = os.path.dirname(os.path.abspath(__file__))
sys.path.append(os.path.dirname(SCRIPT_DIR))
from mypackage.mymodule import as_int
这是一种痛苦,但有一个线索,为什么在一封由某个Guido van Rossum写的电子邮件中。。。
我对这件事和任何其他提议的无聊事都持反对态度__机械唯一的用例似乎是运行发生的脚本生活在模块的目录中,我一直认为反模式。要让我改变主意,你必须说服我它不是。
在包中运行脚本是否是反模式是主观的,但就我个人而言,我发现它在包含一些自定义wxPython小部件的包中非常有用,因此我可以为任何源文件运行脚本,以显示仅包含该小部件的wx.Frame,用于测试目的。