1

我已经搜索了这个并找到了很多答案,所有这些都告诉我要做我正在做的事情,这是我的目录结构:

app/
+-- __init__.py
+-- app_manager.py
+-- app_gui/
|   +-- __init__.py
|   +-- app_gui.py

在 app_gui.py 我有:

import tkinter as tk
from tkinter import ttk
from app_manager import AppManager

在应用管理器中:

class AppManager():
    def __init__(self):
    """ default constructor for app manager """

在 Visual Code 中,它实际上将此解析为自动完成,这告诉我至少 Visual Code 认为它正确完成。但是,如果我运行它,我会收到以下错误:

ModuleNotFoundError: No Module named "app_manager"

编辑

更改为时的完整堆栈跟踪from app.app_manager import AppManager

Traceback (most recent call last):
   File ".\app_gui\app_gui.py", line 4, in <module>
     from app_manager import AppManager
ModuleNotFoundError: No module named 'app_manager' 
4

2 回答 2

2

由于app_manager.py是上面的目录app_gui.py,我相信您的导入(如果您希望使用相对导入)应该是

from ..app_manager import AppManager

编辑以解决评论中的错误:如果您尝试直接运行此文件,您将ValueError在评论中得到一个赞。相对导入在包内的模块之间起作用。假设你使用了我上面写的导入,然后你有一个比你的app目录高一层的文件,名为stuff.py,包含以下内容:

import app.app_gui.app_gui
print('hello')

运行stuff.py看起来像:

$ python stuff.py 
hello

换句话说,直接使用 python 解释器执行具有相对导入的文件将导致错误,因为它不打算以这种方式使用。相反,您的模型应该由模块本身之外的东西导入和执行。

如果您的目录中有一个__main__包含app完全相同代码的文件,您也可以直接执行该模块。

$ cat app/__main__.py 
import app.app_gui.app_gui
print('hello')

$ python -m app
hello
于 2017-11-17T01:42:37.690 回答
0

像这样运行python代码充其量是hacky。

使用setup.py
这将需要一些小的更改,但会立即带来好处。
然后,您将能够app像使用任何其他已安装的软件包一样使用您的软件包。

新目录结构

.
├── app
│   ├── app_gui
│   │   ├── app_gui.py
│   │   └── __init__.py
│   ├── app_manager.py
│   └── __init__.py
└── setup.py

安装程序.py

from setuptools import find_packages, setup

setup(name='app',
      version='0.0.1-dev',
      description='My app package',
      install_requires=['tkinter'],
      packages=find_packages(),
      zip_safe=False)

app_gui.py

from app.app_manager import AppManager

manager = AppManager()

把它们放在一起

从与运行相同的目录setup.py
$> python setup.py develop

这会将包符号链接到您的 site-pacakges 文件夹中,您可以像对待任何其他包一样对待它。即使用import app从位于系统上任何位置的脚本导入它。

于 2017-11-17T02:07:42.087 回答