构建python项目

时间:2019-01-29 16:40:02

标签: python python-packaging

我需要知道如何设置__init__.py并导入,以构建一个python项目,在其中我可以在整个包中使用完全限定的名称。

该软件包将包含许多子软件包,其中可能包含冲突的名称。包中包含的类将彼此子类化,并包含彼此的引用。该项目将生成,因此使用完全限定的名称将使生活变得更加简单。

该示例项目代表了我要针对的结构,但只包含一个子项目,而IDE似乎对它运行时失败感到满意。

MyPackage / __ init __。py

import SubPackage as SubPackage

MyPackage / SubPackage / __ init __。py

from .FileB import ClassB
from .FileA import ClassA

MyPackage / SubPackage / FileA.py

from __future__ import absolute_import
import MyPackage


class ClassA(MyPackage.SubPackage.ClassB):
    thingA: 'MyPackage.SubPackage.ClassA'
    thingB: MyPackage.SubPackage.ClassB

    def __init__(self):
        self.thingA = None
        self.thingB = None

    def test(self):
        self.thingA = MyPackage.SubPackage.ClassA()
        self.thingB = MyPackage.SubPackage.ClassB()

MyPackage / SubPackage / FileB.py

from __future__ import absolute_import
import MyPackage


class ClassB(object):
    nextB: 'MyPackage.SubPackage.ClassB'

    def __init__(self):
        self.nextB= None

    def test(self):
        self.nextB= MyPackage.SubPackage.ClassB()

test.py

import MyPackage

x = MyPackage.SubPackage.ClassA()

错误

  File "C:\temp\Test.py", line 3, in <module>
    import GeneratedLx
  File "C:\temp\MyPackage\__init__.py", line 1, in <module>
    import Bs as Bs
  File "C:\temp\MyPackage\SubPackage\__init__.py", line 12, in <module>
    from .FileA import ClassA
  File "C:\temp\MyPackage\SubPackage\FileA.py", line 5, in <module>
    class ClassA(MyPackage.SubPackage.ClassB):
AttributeError: module 'MyPackage' has no attribute 'SubPackage'

1 个答案:

答案 0 :(得分:2)

您已经不能在SubPackage级别上发生名称冲突,因此添加MyPackage完全是多余的,并且不能完全按照您尝试的方式使用。这可能是由于绑定名称或其他原因引起的,但是最终在您需要时没有实例。这使您可以稍微编辑以下文件:“ FileA.py” “ FileB.py”

FileA.py

from __future__ import absolute_import
from MyPackage import SubPackage


class ClassA(SubPackage.ClassB):
    thingA: 'SubPackage.ClassA'
    thingB: SubPackage.ClassB

    def __init__(self):
        self.thingA = None
        self.thingB = None

    def test(self):
        self.thingA = SubPackage.ClassA()
        self.thingB = SubPackage.ClassB()

FileB.py

from __future__ import absolute_import
from MyPackage import SubPackage


class ClassB(object):
    nextB: 'SubPackage.ClassB'

    def __init__(self):
        self.nextB= None

    def test(self):
        self.nextB= SubPackage.ClassB()

import语句也等效于from .. import Subpackage,但使用相对导入而不是绝对导入(如果需要)。从风格上讲,我倾向于使用相对导入来帮助我快速找出哪些导入是项目的一部分,哪些是外部依赖项。