如果对您有一丁点帮助,劳烦动动手指点个赞,支持和鼓励是搬砖人不断创作的动力!
随着代码量的膨胀,原有的管理方式力不从心,我们需要更高层次的抽象来应对复杂性。最初,函数的出现将实现同一功能的语句有效聚合。进而面向对象思想产生,通过类和对象将数据与行为打包。当类和函数愈发繁多,我们将之有机组合为模块。最终模块集结为包,完成了从庞杂到系统的飞跃。
Python 程序由模块组成。一个模块对应 python 源文件,一般后缀名是:.py。
模块由语句组成。运行 Python 程序时,按照模块中语句的顺序依次执行。
语句是 Python 程序的构造单元,用于创建对象、变量赋值、调用函数、控制语句等。
与函数类似,模块也分为标准库模块和用户自定义模块。
Python 标准库提供了操作系统功能、网络通信、文本处理、文件处理、数学运算等基 本的功能。比如:random(随机数)、math(数学运算)、time(时间处理)、file(文件处理)、 os(和操作系统交互)、sys(和解释器交互)等。
另外,Python 还提供了海量的第三方模块,使用方式和标准库类似。功能覆盖了我们 能想象到的所有领域,比如:科学计算、WEB开发、大数据、人工智能、图形系统等。
模块(module)对应于 Python 源代码文件(.py 文件)。模块中可以定义变量、函数、 类、普通语句。 这样,我们可以将一个 Python 程序分解成多个模块,便于后期的重 复应用。
模块化编程(Modular Programming)将一个任务分解成多个模块。每个模块
就像一个积木一样,便于后期的反复使用、反复搭建。
模块化编程有如下几个重要优势:
模块化编程的一般流程:
API(Application Programming Interface 应用程序编程接口)是用于描述模 块中提供的函数和类的功能描述和使用方式描述。
模块化编程中,首先设计的就是模块的 API(即要实现的功能描述),然后开始编 码实现 API中描述的功能。最后,在其他模块中导入本模块进行调用。
我们可以通过 help(模块名)查看模块的 API。一般使用时先导入模块 然后通过 help
函数查看。
【示例】导入 math 模块,并通过 help()查看 math 模块的 API:
import math
help(math)
也可以在 python 的 api 文档中查询。首先进入 python 的安装目录下的 docs 子目录:
双击打开 chm 文档,即可通过索引输入“math”查询到对应的 API内容:
【示例】设计计算薪水模块的 API
""" 本模块用于计算公司员工的薪资 """
company = "码农科技"
def yearSalary(monthSalary):
"""根据传入的月薪,计算出年薪"""
pass
def daySalary(monthSalary):
"""根据传入的月薪,计算出每天的薪资"""
pass
如上模块只有功能描述和规范,需要编码人员按照要求实现编码。 我们可以通过__doc__可以获得模块的文档字符串的内容。
test.py 的源代码:
import salary
print(salary.__doc__)
print(salary.yearSalary.__doc__)
运行结果:
本模块用于计算公司员工的薪资 根据传入的月薪,计算出年薪
每个模块都有一个名称,通过特殊变量__name__可以获取模块的名称。在正常情况
下,模块名字对应源文件名。 仅有一个例外,就是当一个模块被作为程序入口时(主 程序、交互式提示符下),它的__name__的值为“__main__”。我们可以根据这个特 点,将模块源代码文件中的测试代码进行独立的处理。例如:
import math
math.__name__ #输出’math’
【示例】通过__name==“__main__”独立处理模块的测试代码
"""
本模块用于计算公司员工的薪资
"""
company = "码农科技"
def yearSalary(monthSalary):
"""根据传入的月薪,计算出年薪"""
return monthSalary*12
def daySalary(monthSalary):
"""根据传入的月薪,计算出每天的薪资"""
return monthSalary/22.5 #国家规定每个月的平均工作日是 22.5
if __name__ =="__main__": #测试代码
print(yearSalary(3000))
print(daySalary(3000))
我们可以在模块的第一行增加一个文档字符串,用于描述模块的相关功能。然后,通过 __doc__可以获得文档字符串的内容。
【示例】模块文档字符串示例以及导入后如何读取文档字符串 test.py 的源代码:
import MySalary
print(MySalary.__doc__)
print(MySalary.yearSalary.__doc__)
运行结果:
本模块实现根据月薪计算各种薪水的功能 根据月薪,计算年薪
模块化设计的好处之一就是“代码复用性高”。写好的模块可以被反复调用,重复使用。 模块的导入就是“在本模块中使用其他模块”。
import 语句的基本语法格式如下:
import 模块名 #导入一个模块
import 模块 1,模块 2… #导入多个模块
import 模块名 as 模块别名 #导入模块并使用新名字
import 加载的模块分为四个通用类别:
a.使用 python 编写的代码(.py 文件);
b.已被编译为共享库或 DLL的 C 或 C++扩展;
c.包好一组模块的包
d.使用 C 编写并链接到 python 解释器的内置模块;
我们一般通过 import 语句实现模块的导入和使用,import 本质上是使用了内置函数 __import__()。
当我们通过 import 导入一个模块时,python 解释器进行执行,最终会生成一个对象, 这个对象就代表了被加载的模块。
import math
print(id(math))
print(type(math))
print(math.pi) #通过 math.成员名来访问模块中的成员
执行结果是: 31840800
由上,我们可以看到 math 模块被加载后,实际会生成一个 module 类的对象,该对象被 math 变量引用。我们可以通过 math 变量引用模块中所有的内容。
我们通过 import 导入多个模块,本质上也是生成多个 module 类的对象而已。
有时候,我们也需要给模块起个别名,本质上,这个别名仅仅是新创建一个变量引用加 载的模块对象而已。
import math as m
#import math
#m = math
print(m.sqrt(4)) #开方运算
Python 中可以使用 from…import 导入模块中的成员。基本语法格式如下:
from 模块名 import 成员 1,成员 2,…
如果希望导入一个模块中的所有成员,则可以采用如下方式:
from 模块名 import *
【注】尽量避免“from 模块名 import *”这种写法。* 它表示导入模块中所有的不 是以下划线(_)开头的名字都导入到当前位置。 但你不知道你导入什么名字,很有可能
会覆盖掉你之前已经定义的名字。而且可读性极其的差。一般生产环境中尽量避免使用, 学习时没有关系。
【示例】使用 from…import 导入模块指定的成员
from math import pi,sin
print(sin(pi/2)) #输出 1.0
import 导入的是模块。from…import 导入的是模块中的一个函数/一个类。
如果进行类比的话,import 导入的是“文件”,我们要使用该“文件”下的内容,必 须前面加“文件名称”。from…import 导入的是文件下的“内容”,我们直接使用这 些“内容”即可,前面再也不需要加“文件名称”了。
我们自定义一个模块 calculator.py:
"""一个实现四则运算的计算器"""
def add(a,b):
return a+b
def minus(a,b):
return a-b
class MyNum():
def print123(self):
print(123)
我们在另一个模块 test.py 测试:
import calculator
a = calculator.add(30,40)
# add(100,200) #不加模块名无法识别
print(a)
from calculator import *
a = add(100,200) #无需模块名,可以直接引用里面的函数/类
print(a)
b = MyNum()
b.print123()
import 语句本质上就是调用内置函数__import__(),我们可以通过它实现动态导入。给 __import__()动态传递不同的的参数值,就能导入不同的模块。
【示例】使用__import__()动态导入指定的模块
s = "math"
m = __import__(s) #导入后生成的模块对象的引用给变量 m
print(m.pi)
注意:一般不建议我们自行使用__import__()导入,其行为在 python2 和 python3 中 有差异,会导致意外错误。如果需要动态导入可以使用 importlib 模块。
import importlib
a = importlib.import_module("math")
print(a.pi)
当导入一个模块时, 模块中的代码都会被执行。不过,如果再次导入这个模块, 则不会再次执行。
Python 的设计者为什么这么设计?因为,导入模块更多的时候需要的是定义模块 中 的 变 量 、 函 数 、 对 象 等 。 这 些 并 不 需 要 反 复 定 义 和 执 行 。 “ 只 导 入 一 次 import-only-once”就成了一种优化。
一个模块无论导入多少次,这个模块在整个解释器进程内有且仅有一个实例对象。
test02.py 的源代码:
print("test 模块被加载了...")
test03.py 的源代码:
import test02 #会执行 test02 模块中的语句
import test02 #不会再执行 test02 模块中的语句
import test02
import test02
print("####")
import importlib importlib.reload(test02)
当一个项目中有很多个模块时,需要再进行组织。我们将功能类似的模块放到一起, 形成了“包”。本质上,“包”就是一个必须有__init__.py 的文件夹。典型结构如下:
包下面可以包含“模块(module)”,也可以再包含“子包(subpackage)”。就像文件 夹下面可以有文件,也可以有子文件夹一样。
上图中,a 是上层的包,下面有一个子包:aa。可以看到每个包里面都有__init__.py 文件。
在 pycharm 开发环境中创建包,非常简单。在要创建包的地方单击右键:New–>Python package 即可。pycharm 会自动帮助我们生成带有__init__.py 文件的包。
上一节中的包结构,我们需要导入 module_AA.py。方式如下:
在使用时,直接可以使用模块名。 比如:module_AA.fun_AA()
【注】
类、变量。
导入包的本质其实是“导入了包的__init__.py”文件。也就是说,”import pack1”意味 着执行了包 pack1 下面的__init__.py 文件。 这样,可以在__init__.py 中批量导入我们需要 的模块,而不再需要一个个导入。
__init__.py 的三个核心作用:
【示例】测试包的__init__.py 文件本质用法
a 包下的__init__.py 文件内容:
import turtle
import math
print("导入 a 包")
b 包下的 module_B1.py 文件中导入 a 包,代码如下:
import a
print(a.math.pi)
执行结果如下:
导入 a 包 3.141592653589793
【注】如上测试我们可以看出 python 的设计者非常巧妙的通过__init__.py 文件将包转成了 模块的操作。因此,可以说“包的本质还是模块”。
import * 这样的语句理论上是希望文件系统找出包中所有的子模块,然后导入它们。 这可能会花长时间等。Python 解决方案是提供一个明确的包索引。
这 个 索 引 由 __init__.py 定 义 __all__ 变 量 , 该 变 量 为 一 列 表 , 如 上 例 a 包 下 的 __init__.py 中,可定义 __all__ = [“module_A”,“module_A2”]
这意味着, from sound.effects import * 会从对应的包中导入以上两个子模块;
【注】尽管提供 import * 的方法,仍不建议在生产代码中使用这种写法。
如果是子包内的引用,可以按相对位置引入子模块 以 aa 包下的 module_AA 中导入 a 包下内容为例:
from … import module_A #…表示上级目录 .表示同级目录
from . import module_A2 #.表示同级目录
当我们导入某个模块文件时, Python 解释器去哪里找这个文件呢?只有找到这个文 件才能读取、装载运行该模块文件。它一般按照如下路径寻找模块文件(按照顺序寻找,找 到即停不继续往下寻找):
当任何一个 python 程序启动时,就将上面这些搜索路径(除内置模块以外的路径)进行收集, 放到 sys 模块的 path 属性中(sys.path)。
我们在项目的 b 目录下建立测试模块:
import sys
sys.path.append(“d:/”)
print(sys.path)
执行结果:
windows 系统中通过如下操作添加和设置 pythonpath 环境变量。
我们可以在 site-packages 目录下添加.pth 文件。并在文件中增加内容:
#一行一个目录
g:\a
g:\b
g:\c
【注】
“.pth.”才能正常建立.pth 文件。
当我们完成了某个模块开发后,可以将他对外发布,其他开发者也可以以“第三方扩展 库”的方式使用我们的模块。我们按照如下步骤即可实现模块的发布:
1.为模块文件创建如下结构的文件夹(一般,文件夹的名字和模块的名字一样):
2.在文件夹中创建一个名为『setup.py』的文件,内容如下:
from distutils.core import setup
setup(
name='baizhanMath2', # 对外我们模块的名字
version='1.0', # 版本号
description='这是第一个对外发布的模块,测试哦', #描述
author='gaoqi', # 作者
author_email='[email protected]', py_modules=['baizhanMath2.demo1','baizhanMath2.demo2'] # 要发布的模块
)
3. 构建一个发布文件。通过终端,cd 到模块文件夹 c 下面,再键入命令: python setup.py sdist 执行完毕后,目录结构变为:
将发布安装到你的本地计算机上。仍在 cmd 命令行模式下操作,进 setup.py 所在目 录,键入命令:
python setup.py install
安装成功后,我们进入 python 目录/Lib/site-packages 目录(第三方模块都安装的这 里,python 解释器执行时也会搜索这个路径):
安装成功后,直接使用 import 导入即可。
import baizhanMath2.demo1
将自己开发好的模块上传到 PyPI网站上,将成为公开的资源,可以让全球用户自由使 用。按照如下步骤做,很容易就实现上传模块操作。
·注册 PyPI网站
注册 PyPI网站:http://pypi.python.org
【注意】会发送一封邮件到你的邮箱。请点击验证后继续下面的步骤。 ·创建用户信息文件.pypirc
·方式 1: 使用命令(适用 Linux)
输入并执行后 python setup.py register ,然后输入用户名和密码,即可。
·方式 2:使用文件(适用 windows,Linux) 在用户的家目录里创建一个文件名为.pypirc, 内容为:
[distutils]
index-servers=pypi
[pypi]
repository = https://upload.pypi.org/legacy/
username = 账户名
password = 你自己的密码
【注】
Linux 的家目录: ~/.pypirc
Windows 的家目录是: c:/user/用户名
在 windows 下直接创建不包含文件名的文件会失败,因此创建时文件名为“.pypirc.”, 前后都有两个点即可。
·上传并远程发布
进入 setup.py 文件所在目录,使用命令“python setup.py sdist upload”,即可以 将模块代码上传并发布:
·管理你的模块
我们登录 pypi 官网,可以看到:
如果你的模块已经上传成功,那么当你登录 PyPI 网站后应该能在右侧导航栏看到管理
点击包名进去后你可以对你的模块进行管理,当然你也可以从这里删除这个模块。
模块发布完成后,其他人只需要使用 pip 就可以安装你的模块文件。比如:
如果你更新了模块,别人可以可以通过–update 参数来更新:
pip install package-name update
Python 中库是借用其他编程语言的概念,没有特别具体的定义。模块和包侧重于代码 组织,有明确的定义。
一般情况,库强调的是功能性,而不是代码组织。我们通常将某个功能的“模块的集合”,
称为库。
Python 拥有一个强大的标准库。Python 语言的核心只包含数字、字符串、列表、字典、 文件等常见类型和函数,而由 Python 标准库提供了系统管理、网络通信、文本处理、数据 库接口、图形系统、XML处理等额外的功能。
Python 标准库的主要功能有:
目前学过的有:random、math、time、file、os、sys 等模块。可以通过 random 模 块实现随机数处理、math 模块实现数学相关的运算、time 模块实现时间的处理、file 模块 实现对文件的操作、OS 模块实现和操作系统的交互、sys 模块实现和解释器的交互。
强大的标准库奠定了 python 发展的基石,丰富和不断扩展的第三方库是 python 壮大 的保证。我们可以进入 PyPI官网:
我们可以看到发布的第三方库达到了十多万种,众多的开发者为 Python 贡献了自己的力 量。
表 常用第三方库大汇总
分类 | 库名称 | 说明 |
---|---|---|
环境管理 | P | 非常简单的交互式 python 版本管理工具 |
Pyenv | 简单的 Python 版本管理工具 | |
Vex | 可以在虚拟环境中执行命令 | |
Virtualenv virtualenvwrapp | 创建独立 Python 环境的工具 |
er | ||
---|---|---|
包管理 | pip | Python 包和依赖关系管理工具 |
pip-tools | 保证 Python 包依赖关系更新的一组工具 | |
Pipenv | Python 官方推荐的新一代包管理工具 | |
Poetry | 可完全取代 setup.py 的包管理工具 | |
包仓库 | [warehouse](https://pypi.org/) | 下一代 PyPI |
Devpi | PyPI 服务和打包/测试/分发工具 | |
分发 (打 包 为 可 执 行 文 件 以便分发) |
PyInstaller | 将 Python 程序转成独立的执行文件(跨平台) |
Nuitka | 将脚本、模块、包编译成可执行文件或扩展模块 | |
py2app | 将 Python 脚本变为独立软件包(Mac OS X) | |
py2exe | 将 Python 脚本变为独立软件包(Windows) | |
pynsist | 一个用来创建 Windows 安装程序的工具,可 以在安装程序中打包 Python 本身 | |
构建工具 (将源码编译成软件) | Buildout | 构建系统,从多个组件来创建,组装和部署应用 |
BitBake | 针对嵌入式 Linux 的类似 make 的构建工具 | |
Fabricate | 对任何语言自动找到依赖关系的构建工具 | |
交 互 式 Python 解 析器 | IPython | 功 能 丰 富 的 工 具 , 非 常 有 效 的 使 用 交 互 式 Python |
[bpython](http://hao.jobbole.com/bpython/) | 界面丰富的 Python 解析器 | |
Ptpython | 高 级 交 互 式 Python 解 析 器 , 构 建 于 [python-prompt-toolkit 之上](https://github.com/jonathanslenders/python-prompt-toolkit) | |
文件管理 | Aiofiles | 基于 asyncio,提供文件异步操作 |
Imghdr | (Python 标准库)检测图片类型 | |
Mimetypes | (Python 标准库)将文件名映射为 MIME 类型 | |
path.py | 对 os.path 进行封装的模块 | |
Pathlib | (Python3.4+ 标准库)跨平台的、面向对象的 路径操作库 | |
Unipath | 用面向对象的方式操作文件和目录 | |
Watchdog | 管理文件系统事件的 API 和 shell 工具 | |
日期和时间 | Arrow | 更好的 Python 日期时间操作类库 |
Chronyk | 解析手写格式的时间和日期 | |
Dateutil | Python datetime 模块的扩展 | |
PyTime | 一个简单易用的 Python 模块,用于通过字符 串来操作日期/时间 | |
when.py | 提供用户友好的函数来帮助用户进行常用的日 期和时间操作 | |
文本处理 | [chardet](http://hao.jobbole.com/chardet/) | 字符编码检测器,兼容 Python2 和 Python3 |
Difflib | (Python 标准库)帮助我们进行差异化比较 | |
---|---|---|
Fuzzywuzzy | 模糊字符串匹配 | |
Levenshtein | 快速计算编辑距离以及字符串的相似度 | |
Pypinyin | 汉字拼音转换工具 Python 版 | |
Shortuuid | 一个生成器库,用以生成简洁的,明白的,URL 安全的 UUID | |
[simplejson](https://github.com/simplejson/simplejson) | Python 的 JSON 编码、解码器 | |
Unidecode | Unicode 文本的 ASCII 转换形式 | |
Xpinyin | 一个用于把汉字转换为拼音的库 | |
Pygment | 通用语法高亮工具 | |
Phonenumbers | 解析,格式化,储存,验证电话号码 | |
Sqlparse | 一个无验证的 SQL 解析器 | |
特殊文本格式处理 | Tablib | 一个用来处理中表格数据的模块 |
Pyexcel | 用来读写,操作 Excel 文件的库 | |
python-docx | 读取,查询以及修改 word 文件 | |
PDFMiner | 一个用于从 PDF 文档中抽取信息的工具 | |
Python-Markdo wn2 | 纯 Python 实现的 Markdown 解析器 | |
Csvkit | 用于转换和操作 CSV 的工具 | |
自然语言处理 | [NLTK](http://hao.jobbole.com/nltk/) | 一个先进的平台,用以构建处理人类语言数据的 Python 程序 |
Jieba | 中文分词工具 | |
langid.py | 独立的语言识别系统 | |
SnowNLP | 一个用来处理中文文本的库 | |
Thulac | 清华大学自然语言处理与社会人文计算实验室 研制推出的一套中文词法分析工具包 | |
下载器 | you-get | 一个 YouTube/Youku/Niconico 视频下载器 |
图像处理 | [pillow](http://hao.jobbole.com/pillow/) | 最常用的图像处理库 |
imgSeek | 一个使用视觉相似性搜索一组图片集合的项目 | |
face_recognition | 简单易用的 python 人脸识别 | |
python-qrcode | 一个纯 Python 实现的二维码生成器 | |
OCR | Pyocr | Tesseract 和 Cuneiform 的 一 个 封 装 (wrapper) |
[pytesseract](http://hao.jobbole.com/pytesseract/) | [Google Tesseract OCR ](https://github.com/tesseract-ocr)的 另 一 个 封 装 |
(wrapper) | ||
---|---|---|
音频处理 | Audiolazy | Python 的数字信号处理包 |
Dejavu | 音频指纹提取和识别 | |
id3reader | 一个用来读取 MP3 元数据的 Python 模块 | |
TimeSide | 开源 web 音频处理框架 | |
Tinytag | 一 个 用来 读 取 MP3, OGG, FLAC 以 及 Wave 文件音乐元数据的库 | |
Mingus | 一个高级音乐理论和曲谱包,支持 MIDI 文件 和回放功能 | |
视频和 GIF 处理 | Moviepy | 一个用来进行基于脚本的视频编辑模块,适用于 多种格式,包括动图 GIFs |
scikit-video | SciPy 视频处理常用程序 | |
地理位置 | GeoDjango | 世界级地理图形 web 框架 |
GeoIP | MaxMind GeoIP Legacy 数 据 库 的 Python API | |
Geopy | Python 地址编码工具箱 | |
HTTP | requests | 人性化的 HTTP 请求库 |
httplib2 | 全面的 HTTP 客户端库 | |
urllib3 | 一个具有线程安全连接池,支持文件 post,清 晰友好的 HTTP 库 | |
Python 实现的 数据库 | pickleDB | 一个简单,轻量级键值储存数据库 |
PipelineDB | 流式 SQL 数据库 | |
TinyDB | 一个微型的,面向文档型数据库 | |
web 框架 | [Django](http://hao.jobbole.com/django/) | Python 界最流行的 web 框架 |
[Flask](http://hao.jobbole.com/flask/) | 一个 Python 微型框架 | |
[Tornado](http://hao.jobbole.com/tornado/) | 一个 web 框架和异步网络库 | |
CMS 内容管理系统 | odoo-cms | 一个开源的,企业级 CMS,基于 odoo |
djedi-cms | 一个轻量级但却非常强大的 Django CMS ,考 虑到了插件,内联编辑以及性能 | |
Opps | 一个为杂志,报纸网站以及大流量门户网站设计 的 CMS 平台,基于 Django | |
电 子 商 务 和 支 付 系 统 | django-oscar | 一个用于 Django 的开源的电子商务框架 |
django-shop | 一个基于 Django 的店铺系统 | |
Shoop | 一个基于 Django 的开源电子商务平台 | |
Alipay | Python 支付宝 API | |
Merchant | 一 个 可 以 接 收 来 自 多 种 支 付 平 台 支 付 的 |
Django 应用 | ||
---|---|---|
游戏开发 | Cocos2d | 用来开发 2D 游戏 |
Panda3D | 由迪士尼开发的 3D 游戏引擎,并由卡内基梅 陇娱乐技术中心负责维护。使用 C++ 编写, 针 对 Python 进行了完全的封装 | |
Pygame | Pygame 是一组 Python 模块,用来编写游戏 | |
RenPy | 一个视觉小说(visual novel)引擎 | |
计算机视觉库 | OpenCV | 开源计算机视觉库 |
Pyocr | Tesseract 和 Cuneiform 的包装库 | |
[SimpleCV](http://hao.jobbole.com/simplecv/) | 一个用来创建计算机视觉应用的开源框架 | |
机器学习 人工智能 | [TensorFlow](https://github.com/tensorflow/tensorflow) | 谷歌开源的最受欢迎的深度学习框架 |
[keras](https://github.com/keras-team/keras) | 以 tensorflow/theano/CNTK 为 后 端 的 深 度 学习封装库,快速上手神经网络 | |
Hebel | GPU 加速的深度学习库 | |
[Pytorch](https://github.com/pytorch/pytorch) | 一个具有张量和动态神经网络,并有强大 GPU 加速能力的深度学习框架 | |
scikit-learn | 基于 SciPy 构建的机器学习 Python 模块 | |
NuPIC | 智能计算 Numenta 平台 | |
科 学 计 算 和 数 据 分 析 | [NumPy](http://hao.jobbole.com/numpy/) | 使用 Python 进行科学计算的基础包 |
Pandas | 提供高性能,易用的数据结构和数据分析工具 | |
[SciPy](http://hao.jobbole.com/scipy/) | 用于数学,科学和工程的开源软件构成的生态系 统 | |
[PyMC](http://hao.jobbole.com/pymc/) | 马尔科夫链蒙特卡洛采样工具 | |
代码分析和调试 | code2flow | 把 你的 Python 和 JavaScript 代 码转 换 为流 程图 |
Pycallgraph | 这 个 库 可 以 把 你 的 Python 应 用 的 流 程 (调 用 图)进行可视化 | |
Pylint | 一个完全可定制的源码分析器 | |
autopep8 | 自动格式化 Python 代码,以使其符合 PEP8 规范 | |
Wdb | 一个奇异的 web 调试器,通过 WebSockets 工作 | |
Lineprofiler | 逐行性能分析 | |
[Memory Profiler](http://hao.jobbole.com/memory_profiler/) | 监控 Python 代码的内存使用 | |
图形用户界面 | Pyglet | 一个 Python 的跨平台窗口及多媒体库 |
PyQt | 跨平台用户界面框架 Qt [的 ](http://www.qt.io/)Python 绑定 ,支 持 Qt v4 和 Qt v5 | |
---|---|---|
Tkinter | Tkinter 是 Python GUI 的一个事实标准库 | |
wxPython | wxPython 是 wxWidgets C++ 类 库 和 Python 语言混合的产物 | |
网 络 爬 虫 和 HTML 分析 | Scrapy | 一个快速高级的屏幕爬取及网页采集框架 |
Cola | 一个分布式爬虫框架 | |
Grab | 站点爬取框架 | |
Pyspider | 一个强大的爬虫系统 | |
html2text | 将 HTML 转换为 Markdown 格式文本 | |
[python-goose](http://hao.jobbole.com/python-goose/) | HTML 内容/文章提取器 | |
硬件编程 | Ino | 操作 [Arduino 的](https://www.arduino.cc/)命令行工具 |
Pyro | Python 机器人编程库 | |
PyUserInput | 跨平台的,控制鼠标和键盘的模块 | |
Pingo | Pingo 为类似 Raspberry Pi,pcDuino, Intel Galileo 等设备提供统一的 API |
PyPI(Python Package Index)是 python 官方的第三方库的仓库,所有人都可以下载第三 方库或上传自己开发的库到 PyPI。PyPI 推荐使用 pip 包管理器来下载第三方库。
pip 是一个现代的,通用的 Python 包管理工具。提供了对 Python 包的查找、下载、安 装、卸载的功能。pip 可正常工作在 Windows、Mac OS、Unix/Linux 等操作系统上,但 是需要至少 2.6+和 3.2+的 CPython 或 PyPy 的支持。python 2.7.9 和 3.4 以后的版本已 经内置累 pip 程序,所以不需要安装。
第 三 方 库 有 数 十 万 种 之 多 , 以 pillow 库 为 例 讲 解 第 三 方 扩 展 库 的 安 装 。 pillow 是 Python 平台事实上的图像处理标准库,本节以安装 pillow 为例,给大家介绍第三方库的两 种常用的安装方法。
第一种方式:命令行下远程安装
以安装第三方 pillow 图像库为例,在命令行提示符下输入:pip install pillow 安装完成后,我们就可以开始使用。
第二种方式:Pycharm 中直接安装到项目中
在 Pycharm 中,依次点击:file–>setting–>Project 本项目名–>Project Interpreter
点击“+”,然后输入要安装的第三方库“pillow”,再点击按钮“Install Package”,等待 安装即可,几秒种后,即提示安装成功:
这样,我们就可以在项目中直接使用第三方库 pillow 了。
ID: Txtechcom