import a.b.c
⇒ ImportError: No module named 'a.b.c'; 'a.b' is not a package
import a.b
a ⇒ <module 'a' (namespace)>
a.__path__ ⇒ _NamespacePath(['/.../a'])
a.b ⇒ <module 'a.b' from '/home/cjs/tmp/a/b.py'>
a.b.__path__ ⇒ AttributeError: 'module' object has no attribute '__path__'
6 回答
一个迟到的答案,另一个定义:
所以物理上一个包是一个分发单元,它提供一个或多个模块 .
所以你还记得你的教科书,在内容页面上,章节分为模块 . 因此,概念不同的章节具有相同的目标或相同理论的一部分,然后这些部分聚集在一起并被称为模块 . 类似地,在编程中,当不同的函数聚集在一起时,它们被分开并命名为模块 .
来自Python glossary:
名称中包含短划线的Python文件(如
my-file.py
)无法使用简单的import
语句导入 . 代码方面,import my-file
与import my - file
相同,它将引发异常 . 这些文件更好地表征为脚本,而可导入文件是模块 .任何Python文件都是module,它的名称是文件的基本名称,没有
.py
扩展名 . package是Python模块的集合:虽然模块是单个Python文件,但软件包是包含额外__init__.py
文件的Python模块的目录,用于区分软件包与恰好包含一堆Python脚本的目录 . 如果相应的目录包含自己的__init__.py
文件,则包可以嵌套到任何深度 .模块和包之间的区别似乎只适用于文件系统级别 . 导入模块或包时,Python创建的相应对象始终为
module
类型 . 但是,请注意,导入包时,只能直接看到该包的__init__.py
文件中的变量/函数/类,而不是子包或模块 . 例如,考虑Python标准库中的xml
包:其xml
目录包含__init__.py
文件和四个子目录;子目录etree
包含__init__.py
文件,其中包含ElementTree.py
文件 . 看看当您尝试以交互方式导入包/模块时会发生什么:在Python中还有内置模块,例如
sys
,它们是用C语言编写的,但我认为你不打算考虑那些问题 .首先,请记住,在精确定义中,模块是Python解释器内存中的对象,通常通过从磁盘读取一个或多个文件来创建 . 虽然我们可以非正式地调用磁盘文件,例如
a/b/c.py
"module,",但它不会与来自其他几个来源(例如sys.path
)的信息一起创建模块对象 . (例如,注意,可以从同一文件加载具有不同名称的两个模块,具体取决于sys.path
和其他设置 . )包是一个可能有子模块(包括子包)的模块 . 并非所有模块都能做到这一点 . 例如,创建一个小模块层次结构:
确保
a
下没有其他文件 . 启动Python 3.4或更高版本的解释器(例如,使用python3 -i
)并检查以下语句的结果:模块
a
和a.b
是包(事实上,某种类型的包称为"namespace package,"虽然我们不会在此担心) . 但是,模块a.b.c
不是包 . 我们可以通过在上面的目录结构中添加另一个文件a/b.py
并启动一个新的解释器来证明这一点:Python确保在加载子模块之前加载所有父模块 . 上面发现
a/
是一个目录,因此创建了一个名称空间包a
,a/b.py
是一个Python源文件,它加载并用于创建(非包)模块a.b
. 此时你不能拥有一个模块a.b.c
,因为a.b
不是一个包,因此不能有子模块 .您还可以在此处看到包模块
a
具有__path__
属性(包必须具有此属性),但非包模块a.b
不具有此属性 .模块是在一个导入下导入并使用的单个文件(或多个文件) . 例如
包是目录中的模块集合,用于提供包层次结构 .
Documentation for modules
Introduction to packages