编译安装python需要哪些依赖

Python018

编译安装python需要哪些依赖,第1张

依赖库:

//使用apt 安装即可

1.gcc, make, zlib1g-dev(压缩/解压缩库)

安装过程需要的库。

2.libbz2-dev

bz2支持库,若在编译安装python前没有安装,将无法通过pip install 安装提供bz2格式的第三方库,会出现unsupported archive format: .tar.bz2的错误,例如爬虫库Scrapy依赖的Twisted。

3.libsqlite3-dev

sqlite3支持库,若在编译安装python前没有安装,则python中会缺失sqlite3模块,当引入sqlite3或使用依赖sqllite3的第三方库(例如Scrapy)时,会出现ImportError: No modul named _sqllite3的错误。

//以上为编译安装前需要安装的库,可能不够全面,会不断补充。

4.其他:安装第三方库需要的库

python3-dev, libxml2-dev, libxslt1, libffi-dev, libssl-dev等,在安装第三方库会有具体说明,不做过多解释。

安装:

//通过wget获取压缩包,这里选择3.6.1版

wget https://www.python.org/ftp/python/3.6.1/Python-3.6.1.tar.xz

//解压

tar xJf Python-3.6.1.tar.xz

cd Python-3.6.1

./configure

make

/*这步如果需要sudo,请使用sudo -H命令,即sudo -H make install,避免pip等模块安装失败。

错误示例(pip安装失败):The directory '/home/ls/.cache/pip' or its parent directory is not owned by the current user and caching wheels has been disabled. check the permissions and owner of that directory. If executing pip with sudo, you may want sudo's -H flag.

*/

make install

python解释器的介绍:

解释器由一个编译器和一个虚拟机构成,编译器负责将源代码转换成字节码文件,而虚拟机负责执行字节码。

所以,解释型语言其实也有编译过程,只不过这个编译过程并不是直接生成目标代码,而是中间代码(字节码),然后再通过虚拟机来逐行解释执行字节码。

计算机的大脑是CPU, 中文名叫中央处理器,它仍然不能直接处理 Python 语言。CPU 只能直接处理机器指令语言,那是一种由0和1数字组成的语言,这是一种我们人很难直接写出来的语言。

所以,我们需要一个翻译,把Python语言翻译成 计算机CPU 能听懂的机器指令语言,这样计算机才能按照 我们的Python程序的要求去做事。.py结尾的文件需要解释器去运行执行。

执行过程原理:

1.执行 python XX.py 后,将会启动 Python 的解释器。

2.python解释器的编译器会将.py源文件编译(解释)成字节码生成PyCodeObject字节码对象存放在内存中。

3.python解释器的虚拟机将执行内存中的字节码对象转化为机器语言,虚拟机与操作系统交互,使机器语言在机器硬件上运行。

4.运行结束后python解释器则将PyCodeObject写回到pyc文件中。当python程序第二次运行时,首先程序会在硬盘中寻找pyc文件,如果找到,则直接载入,否则就重复上面的过程。

Python解释器执行程序的三个阶段:

第一步:先启动python3解释器。

第二步:Python3解释器就像一个文本编辑器一样将文件python3 D:\test.py从硬盘读入内存。

第三步:Python3解释器解释执行文件代码。

只有第三阶段才识别python的语法。