面向过程编程
面向过程编程就好比在设计一条产品流水线
模块简介
1.什么是模块?
模块:一系列功能的结合体
2.为什么要用模块?
为了提升开发效率(站在巨人肩膀)
3.模块三种来源
1.内置的(python解释器自带能够直接导入使用)
2.第三方的(别人写好的发布在网上的 需要先下载后使用)
3.自定义的(自己写的)
4.模块的四种表现形式
1 使用python编写的代码(.py文件)
2 已被编译为共享库或DLL的C或C++扩展
3 包好一组模块的包(文件夹)
4 使用C编写并链接到python解释器的内置模块
import句式
多次导入相同模块 只会执行一次
首次导入md模块发生的事情
1.运行导入文件(import句式.py)产生该文件的全局名称空间
2.运行md.py文件
3.产生md.py全局名称空间 运行md文件内代码 将产生的名字全部存档于md.py名称空间
4.在导入文件名称空间产生一个md的名字指向md.py全局名称空间
import句式导入模块之后
通过模块名点的方式就可以使用到模块中所有的名字 并且肯定不会产生冲突(指名道姓)
from...import...句式
from...import...多次导入也只会导入一次
1.先产生执行文件的全局名称空间
2.执行模块文件 产生模块的全局名称空间
3.将模块中执行之后产生的名字全部存档于模块名称空间中
4.在执行文件中有一个money执行模块名称空间中money指向的值
from...import...指名道姓的导入某个名字
在使用的时候直接写名字即可 但是当当前名称空间有相同名字的时候
就会产生冲突 使用的就变成了当前名称空间
导入模块扩展用法
1.起别名
既可以给模块名起别名也可以给模块中某个名字起别名
2.连续导入
import 模块名1,模块名2
3.通用导入
from md import * 将模块中所有的名字全部导入(*表示所有)
判断文件类型
判断py文件是作为模块文件还是执行文件
__name__当文件是执行文件的时候会返回__main__
如果文件是被当做模块导入则返回文件名(模块名)
循环导入
一错再错
1.调换顺序
将彼此导入的句式放在代码的最后
2.函数形式
将导入的句式放入函数体代码 等待所有的名字加载完毕之后再调用
模块导入的顺序
1.先从内存中查找
2.再去内置模块中查找
3.最后去sys.path系统路径查找(自定义模块)
如果都没有查找到则报错
当某个自定义模块查找不到的时候解决方案
1.自己手动将该模块所在的路径添加到sys.path中
import sys
sys.path.append(r'D:\py20\day18\aaa')
2.from...import...句式
from 文件夹名称.文件夹名称 import 模块名
from 文件夹名称.模块名称 import 名字