关于python:Python-中的模块概述及模块定义使用

4次阅读

共计 1466 个字符,预计需要花费 4 分钟才能阅读完成。

模块概述

在 Python 中,一个 .py 文件就是一个模块(Module)。

为了防止模块名抵触,Python 又引入了按目录来组织模块的办法,称为包(Package)。

mycompany
 ├─ web
 │  ├─ __init__.py
 │  ├─ utils.py
 │  └─ www.py
 ├─ __init__.py
 ├─ abc.py
 ├─ xyz.py
 └─ utils.py

引入了包当前,只有顶层的包名不与他人抵触,那所有模块都不会与他人抵触。

当初,abc.py模块的名字就变成了 mycompany.abcxyz.py 的模块名变成了 mycompany.xyzwww.py 模块的名字就变成了 mycompany.web.www,两个文件utils.py 的模块名别离是 mycompany.utilsmycompany.web.utils

每一个包目录上面都会有一个 __init__.py 的文件,这个文件是必须存在的,否则,Python 就把这个目录当成一般目录,而不是一个包。__init__.py能够是空文件,也能够有 Python 代码。

模块名不能和零碎模块名抵触,最好先查看零碎是否已存在该模块,查看办法是在 Python 交互环境中执行import abc,若胜利则阐明零碎曾经存在此模块。

编写模块

编写一个 hello.py 模块:

#!/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 上运行;

第 2 行是规范正文,示意 .py 文件应用规范 UTF- 8 编码;

第 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!
正文完
 0