与在控制台输入python程序,执行命令相比。当我们的程序变得越来越长的时候,我们希望可以在文本编辑器(如sublime text, notepad++)中编写python程序,因为这样的话,我们的程序可以保存为python脚本。但是随着程序的复杂度不断上升,我们希望可以把一个python脚本根据一定的功能分割成多个不同的python module。这样做的好处主要有两个:
- 程序看起来结构更加清晰,易于维护,因为不同的文件可以同时由不同的程序员同时维护,分工合作。
- 如果某个module或者整个package具有较强的复用性,其他的脚本甚至其他的project可以直接引用,避免了重复造轮子。
这样,我们就引出了python中module和package的概念,可以说python当今十分流行的原因之一就是极为丰富的第三方模块,可以让我在完成很多任务的时候,避免了一切从零开始。当然,python本身也提供了十分强大全面的标准库 - Python Standard Library
类似于c++中的include
, PHP中的require
。在python中导入模块有两种方式import
和from ... import ...
,下面我们通过test.py
和example.py
来举例说明。
test.py
a = "Hello"
b = "World"
def Hello():
print("Hello, World")
当两个文件在同一个子目录下
-- project
|-- test.py
`-- example.py
如果我想要在example.py中使用test模块,有下面三种方法:
- 第一种方法
import test
test.Hello() # "Hello, World"
print(test.a) # "Hello"
使用时必须遵守module_name.xxx
的格式,此方法将整个文件都包括进来
- 第二种方法
from test import *
Hello() # "Hello, World"
print(a) # "Hello"
使用第二种方法时,不再需要遵守第一种的格式,*
表示import everything(但这种方式不会导入以下划线开头的名称),通常导致代码非常难读,不赞成使用。相应的应对方法就是通过使用__all__
变量来限制。比如更改 test.py
__all__ = ["a", "b"]
a = "Hello"
b = "World"
def Hello():
print("Hello, World")
这样的话,import *
将不能引入Hello
方法
- 第三种方法
在import的时候就声明具体要引入的内容
from test import Hello
Hello() # "Hello, World"
当主程序所在目录是模块所在目录的父(或祖辈)目录
-- project
|-- module
| `--test.py
`-- example.py
如果要在example.py
中使用test
模块
from module.test import *
或者
import module.test
但要注意必须在module文件夹中添加__init__.py
文件,文件可以为空。