Python模块基础

一、模块的四种形式

1、什么是模块

模块是一系列功能的集合体,而函数是某一个功能的集合体,因此模块可以看成是一推函数的集合体。一个py文件内部就可以放一堆函数,因此一个py文件就可以看成一个模块。如果这个py文件的文件名为module.py,模块名则是module

2、模块的四种形式

在Python中,总共有以下四种形式的模块:

  1. 自定义模块:如果你自己写一个py文件,在文件内写入一堆函数,则它被成为自己定义模块,即使用Python编写的.py文件
  2. 第三方模块:已被编译为共享库或DLL的C或C++扩展
  3. 内置模块:使用C编写并链接到Python解释器的内置模块
  4. 包:把一系列模块组织到一起的文件夹(注:文件夹下有一个_ _ init _ _.py文件,该文件夹称之为包)

二、import和from...import

1、import 模块名

import time 发生的三件事情

  1. 在内存中生成一个叫做time的名称空间
  2. 运行time.py文件,然后把time.py文件内的名称空间放入time的名称空间内
  3. 把time的名称空间指向import和from...import.py(当前导入time模块的文件)的名称空间中

使用import time导入的时候,使用方法只能time.方法名(),不能直接方法名

2、from 模块名 import 具体的功能

from time import gmtime 发生的三件事情

  1. 在内存中生成一个叫做time的名称空间
  2. 运行time.py文件,然后把time.py文件内的名称空间放入time的名称空间内
  3. 把gtime方法指向import和from...import.py(当前导入time模块的文件)的名称空间中

3、import和from...import...的异同

相同点:

  1. 两者都会执行模块对应的文件,两者都会产生模块的名称空间
  2. 两者调用功能时,需要跑到定义时寻找作用域关系,与调用位置无关

不同点

  1. import需要加前缀;from...import...不需要加前缀

三、循环导入

# m1.py
def f2():
    from m2 import y  # ImportError: cannot import name 'y'
    print(y)

x = 10

# 1. 生成一个m2的名称空间
# 2. 运行m2.py这个文件--> from m1 import x --> 生成一个m1的名称空间 --> 运行m1.py这个文件 --> from m2 import y
# 以上现象叫做循环导入问题

# m1中x= 10已经有了
# 运行m2 --> 运行m1 --> 生成x=10 --> 运行m2 --> 运行m1

# m2.py
y = 20

def f1():
    from m1 import x
    # ImportError: cannot import name 'x'
    print(x)

f1()

# 运行m1, 找x ,直接打印了x  --> 返回m1,继续打印y --> 返回m1打印x
# 函数:  y=20+f1--> f1()

# 解决方案
# 1.将from放到函数内
# 2.将from放到文件最底部(不推荐)

四、模块搜索路径的顺序

模块其实就是一个文件,如果要执行文件,首先就需要找到模块的路径(某个文件夹)。如果模块的文件路径和执行文件不在同一个文件目录下,我们就需要指定模块的路径。

模块的搜索路径指的就是在导入模块时需要检索的文件夹。

导入模块时查找模块的顺序是:

  1. 先从内存中已经导入的模块中寻找
  2. 内置的模块
  3. 环境变量sys.path中找

五、Python文件的两种用途

python文件总共有两种用途,一种是执行文件;另一种是被当做模块导入。

编写好的一个python文件可以有两种用途:

  1. 脚本,一个文件就是整个程序,用来被执行
  2. 模块,文件中存放着一堆功能,用来被导入使用
posted @ 2019-08-15 18:23  17vv  阅读(152)  评论(0编辑  收藏  举报