[TOC]
## 模块概念
### 什么是模块
为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码就相对较少,在Python中,一个.py文件就称之为一个模块(Module)。
### 使用模块有什么好处?
最大的好处是大大提高了代码的可维护性。其次,编写代码不必从零开始。当一个模块编写完毕,就可以被其他地方引用。我们在编写程序的时候,也经常引用其他模块,包括Python内置的模块和来自第三方的模块。
使用模块还可以避免函数名和变量名冲突。每个模块有独立的命名空间,因此相同名字的函数和变量完全可以分别存在不同的模块中,所以,我们自己在编写模块时,不必考虑名字会与其他模块冲突
### 模块分类
模块分为三种:
* 内置标准模块
又称标准库,执行help('modules')查看所有python自带模块列表
* 第三方开源模块,可通过pip install 模块名 联网安装
* 自定义模块
### 模块调用
```python
import module
from module import xx
from module.xx.xx import xx as rename
from module.xx.xx import *
```
> 注意:模块一旦被调用,即相当于执行了另外一个py文件里的代码
### 自定义模块
创建一个.py文件,就可以称之为模块,就可以在另外一个程序里导入
### 模块查找路径
```python
>>> import sys
>>> print(sys.path)
['C:\\Program Files\\JetBrains\\PyCharm Community Edition 2018.2.1\\helpers\\pydev', 'C:\\Program Files\\JetBrains\\PyCharm Community Edition 2018.2.1\\helpers\\pydev', 'C:\\Program Files\\Python36\\python36.zip', 'C:\\Program Files\\Python36\\DLLs', 'C:\\Program Files\\Python36\\lib', 'C:\\Program Files\\Python36', 'C:\\Program Files\\Python36\\lib\\site-packages', 'D:\\data\\my_python', 'D:/data/my_python']
```
python解释器会按照上面列表顺序去依次到每个目录下去匹配你要导入的模块名,只要在一个目录下匹配到了该模块名,就立刻导入,不再继续往后找,
当前目录最优先,所以自己定义的模块在当前目录会被优先导入。
### 开源模块安装
python的开源模块库:(https://pypi.python.org/pypi),如何从这个平台上下载代码呢?
1. 在线安装
* 通过pip用官方源在线安装
`pip3 install paramiko #paramiko 是模块名`
pip命令会自动下载模块包并完成安装。
* 通过pip用国内源在线安装
`pip install -i http://pypi.douban.com/simple/ paramiko --trusted-host pypi.douban.com`
2. 离线安装
* 下载源码安装
直接在上面这个页面搜索需要的模块,找到后上点download,下载后,解压并进入目录,执行以下命令完成安装
`python setup.py build #先编译源码`
`python setup.py install #再安装源码`
* 通过pip命令离线安装
国内网络不好或者环境不能上网的情况下,可以下载好对应的压缩包,然后通过pip3离线安装
`pip3 install paramiko-2.4.2.tar.gz`
3. 安装的位置
软件一般会被自动安装你python安装目录的`site-packages`子目录里,如windows中的安装位置是`C:\Program Files\Python36\Lib\site-packages`
## 包(Package)的概念
### 单级包
当模块文件越来越多,就需要对模块文件进行划分,比如把负责跟数据库交互的都放一个文件夹,把与页面交互相关的放一个文件夹,Python引入了按目录来组织模块的方法,称为包(Package)。
比如mycompany,按照如下目录存放:
```
mycompany
├─ __init__.py
├─ abc.py
└─ xyz.py
```
abc.py模块的名字就变成了mycompany.abc,xyz.py的模块名变成了mycompany.xyz。
### 注意事项:
请注意,每一个包目录下面都会有一个__init__.py的文件,这个文件是必须存在的,否则,Python就把这个目录当成普通目录,而不是一个包。__init__.py可以是空文件,也可以有Python代码,因为__init__.py本身就是一个模块,而它的模块名就是mycompany。
文件夹被python解释器视作package需要满足两个条件:
* 文件夹中必须有__init__.py文件,该文件可以为空,但必须存在该文件。
* 不能作为顶层模块来执行该文件夹中的py文件(即不能作为主函数的入口)。
### 多级包
类似的,可以有多级目录,组成多级层次的包结构。比如如下的目录结构:
```
mycompany
├─ __init__.py
├─ web
│ ├─ __init__.py
│ ├─ utils.py
│ └─ www.py
├─ abc.py
└─ xyz.py
```
文件www.py的模块名就是mycompany.web.www
>自建模块时要注意命名,不能和Python自带的模块名称冲突。例如,系统自带了sys模块,自己的模块就不可命名为sys.py,否则将无法导入系统自带的sys模块。
## 总结
模块是一组Python代码的集合,可以使用其他模块,也可以被其他模块使用。
模块名要遵循Python变量命名规范,不要使用中文、特殊字符;
模块名不要和系统模块名冲突,最好先查看系统是否已存在该模块,检查方法是在Python交互环境执行import abc,若成功则说明系统存在此模块。
- 基础部分
- 基础知识
- 变量
- 数据类型
- 数字与布尔详解
- 列表详解list
- 字符串详解str
- 元组详解tup
- 字典详解dict
- 集合详解set
- 运算符
- 流程控制与循环
- 字符编码
- 编的小程序
- 三级菜单
- 斐波那契数列
- 汉诺塔
- 文件操作
- 函数相关
- 函数基础知识
- 函数进阶知识
- lambda与map-filter-reduce
- 装饰器知识
- 生成器和迭代器
- 琢磨的小技巧
- 通过operator函数将字符串转换回运算符
- 目录规范
- 异常处理
- 常用模块
- 模块和包相关概念
- 绝对导入&相对导入
- pip使用第三方源
- time&datetime模块
- random随机数模块
- os 系统交互模块
- sys系统模块
- shutil复制&打包模块
- json&pickle&shelve模块
- xml序列化模块
- configparser配置模块
- hashlib哈希模块
- subprocess命令模块
- 日志logging模块基础
- 日志logging模块进阶
- 日志重复输出问题
- re正则表达式模块
- struct字节处理模块
- abc抽象类与多态模块
- requests与urllib网络访问模块
- 参数控制模块1-optparse-过时
- 参数控制模块2-argparse
- pymysql数据库模块
- requests网络请求模块
- 面向对象
- 面向对象相关概念
- 类与对象基础操作
- 继承-派生和组合
- 抽象类与接口
- 多态与鸭子类型
- 封装-隐藏与扩展性
- 绑定方法与非绑定方法
- 反射-字符串映射属性
- 类相关内置方法
- 元类自定义及单例模式
- 面向对象的软件开发
- 网络-并发编程
- 网络编程SOCKET
- socket简介和入门
- socket代码实例
- 粘包及粘包解决办法
- 基于UDP协议的socket
- 文件传输程序实战
- socketserver并发模块
- 多进程multiprocessing模块
- 进程理论知识
- 多进程与守护进程
- 锁-信号量-事件
- 队列与生产消费模型
- 进程池Pool
- 多线程threading模块
- 进程理论和GIL锁
- 死锁与递归锁
- 多线程与守护线程
- 定时器-条件-队列
- 线程池与进程池(新方法)
- 协程与IO模型
- 协程理论知识
- gevent与greenlet模块
- 5种网络IO模型
- 非阻塞与多路复用IO实现
- 带着目标学python
- Pycharm基本使用
- 爬虫
- 案例-爬mzitu美女
- 案例-爬小说
- beautifulsoup解析模块
- etree中的xpath解析模块
- 反爬对抗-普通验证码
- 反爬对抗-session登录
- 反爬对抗-代理池
- 爬虫技巧-线程池
- 爬虫对抗-图片懒加载
- selenium浏览器模拟