在Python中,一个 .py
文件就是一个模块(Module)。python
为了不模块名冲突,Python又引入了按目录来组织模块的方法,称为包(Package)。web
mycompany ├─ web │ ├─ __init__.py │ ├─ utils.py │ └─ www.py ├─ __init__.py ├─ abc.py ├─ xyz.py └─ utils.py
引入了包之后,只要顶层的包名不与别人冲突,那全部模块都不会与别人冲突。函数
如今,abc.py
模块的名字就变成了mycompany.abc
,xyz.py
的模块名变成了mycompany.xyz
;www.py
模块的名字就变成了mycompany.web.www
,两个文件utils.py
的模块名分别是mycompany.utils
和mycompany.web.utils
。测试
每个包目录下面都会有一个__init__.py
的文件,这个文件是必须存在的,不然,Python就把这个目录当成普通目录,而不是一个包。__init__.py
能够是空文件,也能够有Python代码。编码
模块名不能和系统模块名冲突,最好先查看系统是否已存在该模块,查看方法是在Python交互环境中执行import abc
,若成功则说明系统已经存在此模块。命令行
编写一个 hello.py 模块:code
#!/usr/bin/env python3 # -*- coding: utf-8 -*- ' a test module ' __author__ = 'Michael Liao' import sys def test(): args = sys.argv if len(args)==1: print('Hello, world!') elif len(args)==2: print('Hello, %s!' % args[1]) else: print('Too many arguments!') if __name__=='__main__': test()
第1行是标准注释,可让这个 .py
文件直接在 Unix/Linux/Mac 上运行;utf-8
第2行是标准注释,表示 .py
文件使用标准UTF-8编码;ci
第4行是一个字符串,表示模块的文档注释,任何模块代码的第一个字符串都被视为模块的文档注释;文档
第6行使用 __author__
特殊变量记录做者名称;
第8行导入系统内建的sys
模块,sys
模块有一个 argv
变量,用list存储了命令行的全部参数。argv
至少有一个元素,第一个参数永远是该 .py 文件的名称。
运行python3 hello.py
得到的sys.argv
就是['hello.py']
;运行
python3 hello.py Wu
得到的sys.argv
就是['hello.py', 'Wu']
。
最后两行代码的意义为:当咱们在命令行运行 hello
模块文件时,Python解释器把一个特殊变量 __name__
置为 __main__
,而若是在其余地方导入该hello
模块时则不会设置,所以这种if
测试可让一个模块经过命令行运行时执行一些额外的代码,最多见的就是运行测试。
咱们能够用命令行运行 hello.py
看看效果:
$ python3 hello.py Hello, world! $ python hello.py Wu Hello, Wu!
若是启动Python交互环境,再导入hello
模块:
$ python3 >>> import hello >>>
导入时,没有打印 Hello, word!
,由于没有执行test()
函数。
这时候须要调用 hello.test()
,才能打印出Hello, word!
:
>>> hello.test() Hello, world!