模块

什么是模块
模块:就是一系列功能的结合体
模块的三种来源:
1.内置的(python解释器自带)
2.第三方的(别人写的)
3.自定义的(你自己写的)
模块的四种表现形式
1.使用python编写的py文件(也就意味着py文件也可以称之为模块:一个py文件也可以称之为一个模块)
2.已被编译为共享库或DLL的C或C++扩展(了解)
3.把一系列模块组织到一起的文件夹(文件夹下有一个__init__.py文件,该文件夹称之为包)
   包:一系列py文件的结合体
4.使用C编写并连接到python解释器的内置模块

为什么要用模块
1.用别人写好的模块(内置的,第三方的):典型的拿来主义,极大的提高开发效率
2.使用自己写的模块(自定义的):当程序比较庞大的时候,你的项目不可能只在一个py中,那么当多个文件中都需要使用相同的方法的时候 可以将该公共的方法写到一个py文件中,其他的文件以模块的形式导过去直接调用即可。

如何使用模块
注意(******):一定要区分哪个是执行文件,哪个是被导入文件

#  md.py
print('from the md.py')
money = 1000
def read1():
    print('md',money)
def red2():
    print('md模块')
    read1()
def change():
    global money
    money = 0

#  run.py
import md   #模块名叫md.py但是导入的时候只需要写md,千万不要加上文件的后缀

import md    #多次不会运行md文件,都是无效的

money = 9999
def read1():
    print('from run read1')
# 访问模块中的名字指向的值
print(md.money) # 使用import导入模块 访问模块名称空间中的名字,统一句势:模块名.名字md.read1()
md.read2()
print(md.change)
md1.change()
print(money)
print(md1.money)
View Code

以md文件为例

右键运行run.py文件首先会创建一个run.py的名称空间
首次导入模块(md.py)
      1.执行md.py文件
      2.运行md.py文件中的代码将产生的名字与值存放到md.py名称空间中
      3.在执行文件中产生一个指向名称空间的名字(md)

        多次导入不会再执行模块文件,会沿用第一次导入的成果

函数里的两个知识点
      1.只要你能拿到函数名 无论在哪都可以通过函数加括号来调用这个函数(会回到函数定义阶段 依次执行代码)

      2.函数在定义阶段 名字查找就已经固定死了 不会因为调用位置的变化而改变

 使用import导入模块 访问模块名称空间中的名字统一句势:模块名.名字

      1.指名道姓的访问模块中的名字 永远不会与执行文件中的名字冲突
      2.你如果想访问模块中名字 必须用模块名.名字的方式

import md,os,time,import支持一行打开多个模块,但是不推荐使用,因为这样结构不清晰,只有当几个模块有相同部分或者属于同一个模块,可以使用上面的方法,当几个模块没有联系的情况下 应该分多次导入

import os
import time
import md
ps:通常导入模块的句式会写在文件的开头

当模块名字比较长的情况下 可以给该模块名取别名

异常有两大类
1.语法结构错误:需要你当场修改捕获没法完成

2.逻辑错误:异常捕获可以处理

利用from...import...句式
缺点:
1.访问模块中的名字不需要加模块名前缀
2.在访问模块中的名字可能会与当前执行文件中的名字冲突
"""
def read1():
    print('run1.py')
    read1()

# 补充
from ... import * # 一次性将模块中的名字全部加载过来,但是不推荐使用,因为你根本不知道到底有哪些名字可以用
print(money)
print(read1)
print(read2)
print(change)

__all__可以指定当所在py文件被当做模块导入的时候,可以限制导入者能够拿到的名字个数

#m1文件
print('正在导入m1')
form m2 import y


x = 'm1'


#m2文件
print('正在导入m2')
from m1 import x   #第二次导m1
y = 'm2'


#run文件
import m1 #首次导入m1




打印结果
     正在导入m1
     正在导入m2
View Code

如果出现循环导入问题 那么一定是你的程序设计的不合理

循环导入问题应该在程序设计阶段就应该避免

解决循环导入问题的方式
1.方式1
将循环导入的句式写在文件最下方()
2.方式2
函数内导入模块

模块的查找顺序

#1、先从内存里面找
#创建md.py文件
import time
import md   #把md文件拿过来
time.sleep(20)    #然后让它睡20秒,把md文件删除
md.f1()   #from md f1
#第二次就报错了,因为把文件删了
 #2、在内置中找
 #创建一个time.py文件
import time
print(time.time())    #time与模块名冲突
#注:py文件明不应该与模块名冲突

#3、sys.path中找
from dir1.dir import md
#点的左边肯定是一个文件夹,点的右边可以是文件夹,也可以是文件
View Code

一定要分清楚谁是执行文件谁是被导入文件(******)

是动态变化的是一个大列表,里面放了一堆文件路径,第一个路径永远是执行文件所在的文件夹

文件的绝对导入

绝对导入必须依据执行文件所在的文件夹路径为准
1.绝对导入无论在执行文件中还是被导入文件都适用

相对导入
.代表的当前路径
..代表的上一级路径
...代表的是上上一级路径

注意相对导入不能再执行文件中使用
相对导入只能在被导入的模块中使用,使用相对导入 就不需要考虑
执行文件到底是谁 只需要知道模块与模块之间路径关系

 

posted @ 2019-07-16 20:19  Aomur  阅读(292)  评论(0编辑  收藏  举报