Python入门之模块和包用法详解

模块

Python 模块(Module),是一个 Python 文件,以 .py 结尾,包含了 Python 对象定义和 Python 语句

模块能定义函数,类和变量,模块里也能包含可执行的代码

1. 导入模块的方式

  • import 模块名
  • from 模块名 import 功能名
  • from 模块名 import *
  • import 模块名 as 别名
  • from 模块名 import 功能名 as 别名

2. 导入方式详解

import

语法

# 1. 导入模块
import 模块名
import 模块名1,模块名2

# 2. 调用功能
模块名.功能名()

体验

import math
print(math.sqrt(9))  # 3.0

from…import…

语法

from 模块名 import 功能1,功能2,功能3...

体验

from math import sqrt
print(sqrt(9))

from… import *

语法

from 模块名 import *

体验

from math import *
print(sqrt(9))

as定义别名

语法

# 模块定义别名
import 模块名 as 别名

​​​​​​​# 功能定义别名
from 模块名 import 功能 as 别名

体验

# 模块别名
import time as tt

tt.sleep(2)
print('hello')

# 功能别名
from time import sleep as sl
sl(2)
print('hello')

注意:定义别名后不能再使用原功能名

3. 制作模块

在 Python 中,每个 Python 文件都可以作为一个模块,模块的名字就是文件的名字,也就是说自定义模块名必须要符合标识符命名规则

① 定义模块

新建一个 Python 文件,命名为 my_module1.py,并定义 testA 函数

def testA(a, b):
    print(a + b)

② 测试模块

在实际开发中,当一个开发人员编写完一个模块后,为了让模块能够在项目中达到想要的效果,这个开发人员会自行在 py 文件中添加一些测试信息,例如,在 my_module1.py 文件中添加以下测试代码

def testA(a, b):
	print(a + b)

# 测试信息
testA(1, 1)

此时,无论是当前文件,还是其他已经导入了该模块的文件,在运行的时候都会自动执行 testA 函数的调用

解决方法如下:

def testA(a, b):
	print(a + b)

# 只在当前文件中调用该函数,其他导入的文件内不符合该条件,则不执行 testA 函数调用
# __name__ 是系统变量,是模块的标识符,值是:如果是自身模块值的 __main__,否则的当前模块名字
if __name__ == '__main__':
	testA(1, 1)

③ 调用模块

import my_module1
my_module1.testA(2,4)

4. 模块定位顺序

当导入一个模块,Python 解析器对模块位置的搜索顺序是:

  1. 当前目录
  2. 如果不在当前目录,Python 则搜索在 shell 变量 PYTHONPATH 下的每个目录
  3. 如果都找不到,Python 会查看默认路径。UNIX 下,默认路径一半为 /usr/local/lib/python/

模块搜索路径存储在 system 模块的 sys.path 变量中,变量里包含当前目录、PYTHONPATH 和由安装过程决定的默认目录

注意

◦ 自己的文件名不要和已有模块名重复,否则导致模块功能无法使用

◦ 使用 from 模块名 import 功能 的时候,如果功能名字重复,调用到的是最后定义或导入的功能

5. __all__

如果一个模块文件由 __all__ 变量,当使用 from xx import * 导入时,只能导入这个列表中的元素

my_module2 模块代码

__all__ = ['testA']

def testA():
	print('testA')

def testB():
	print('testB')

导入模块的文件代码

from my_module2 import *
testA()
testB()

包将有联系的模块组织在一起,即放到同一个文件夹下,并且在这个文件夹创建一个名字为 __init__.py 文件,那么这个文件夹就称之为包

1. 制作包

[New] - [Python Package] - 输入包名 - [OK] - 新建功能模块(有联系的模块)

注意:新建包后,包内部会自动创建 __init__.py 文件,这个文件控制着包的导入行为

快速体验

  • 新建包 my_package
  • 新建包内模块:my_module1 和 my_module2
  • 模块内代码如下
# my_module1
print(1)


def info_print1():
    print('my_module1')
# my_module1
print(2)


def info_print2():
    print('my_module2')

2. 导入包

方法一

import 包名.模块名

包名.模块名.目标

体验

import my_package.my_module1
my_package.my_module1.info_print1()

方法二

注意:必须在 __init__.py 文件中添加 __all__ = [],控制允许导入的模块列表

from 包名 import *
模块名.目标

体验

from my_package import *
my_module1.info_print1()

总结

导入模块方法

import 模块名

from 模块名 import 目标

from 模块名 import *

导入包

import 包名.模块名

from 包名 import *

__all__ = []:允许导入的模块或功能列表

以上就是Python入门之模块和包用法详解的详细内容,更多关于Python模块 包的资料请关注脚本之家其它相关文章!

你可能感兴趣的:(Python入门之模块和包用法详解)