27

我已经开始学习python并编写一个练习应用程序。目录结构看起来像

src
 |
 --ShutterDeck
    |
    --Helper
       |
       --User.py -> class User
    --Controller
       |
       --User.py -> class User

src目录位于PYTHONPATH. 在另一个文件中,可以说main.py,我想访问这两个User类。我该怎么做。

我尝试使用以下方法,但失败了:

import cherrypy
from ShutterDeck.Controller import User
from ShutterDeck.Helper import User

class Root:
  @cherrypy.expose
  def index(self):
    return 'Hello World'

u1=User.User()
u2=User.User()

这当然是模棱两可的。我能想到的另一种(c++ 做它的方式)方式是

import cherrypy
from ShutterDeck import Controller
from ShutterDeck import Helper

class Root:

  @cherrypy.expose
  def index(self):
    return 'Hello World'

u1=Controller.User.User()
u2=Helper.User.User()

但是当上面的脚本运行时,它给出了以下错误

u1=Controller.User.User()
AttributeError: 'module' object has no attribute 'User'

我无法弄清楚为什么会出错?目录ShutterDeckHelperController__init__.py其中。

4

3 回答 3

47

您希望导入User__init__.py文件中的模块以使它们可用作属性。

所以在两者中Helper/__init_.pyController/__init__.py添加:

from . import User

这使模块成为包的属性,您现在可以这样引用它。

或者,您必须完全导入模块本身:

import ShutterDeck.Controller.User
import ShutterDeck.Helper.User

u1=ShutterDeck.Controller.User.User()
u2=ShutterDeck.Helper.User.User()

所以用他们的全名来称呼他们。

另一种选择是使用以下命令重命名导入的名称as

from ShutterDeck.Controller import User as ControllerUser
from ShutterDeck.Helper import User as HelperUser

u1 = ControllerUser.User()
u2 = HelperUser.User()
于 2013-03-30T16:08:25.063 回答
10

一种方法是:

import ShutterDeck.Controller.User
import ShutterDeck.Helper.User

cuser = ShutterDeck.Controller.User.User()
huser = ShutterDeck.Helper.User.User()

你也可以这样做:

from ShutterDeck.Controller.User import User as ControllerUser
from ShutterDeck.Helper.User import User as HelperUser
于 2013-03-30T16:09:22.193 回答
1

这也可能有帮助(今天遇到类似的问题):

ShutterDeck
├── Controller
│   ├── __init__.py
│   └── User.py
├── Helper
│   ├── __init__.py
│   └── User.py
└── __init__.py

ShutterDeck/{Controller,Helper}/__init__.py

from .User import User

进而:

>>> import ShutterDeck.Helper
>>> helperUser = ShutterDeck.Helper.User()
>>> helperUser
<ShutterDeck.Helper.User.User object at 0x1669b90>
>>> import ShutterDeck.Controller
>>> controllerUser = ShutterDeck.Controller.User()
>>> controllerUser
<ShutterDeck.Controller.User.User object at 0x1669c90>
于 2013-10-26T11:54:09.147 回答