为什么要编译Python脚本?您可以直接从.py文件运行它们,它工作得很好,那么是否有性能优势或其他什么?
我还注意到我的应用程序中的一些文件被编译成.pyc,而其他文件则没有,这是为什么?
为什么要编译Python脚本?您可以直接从.py文件运行它们,它工作得很好,那么是否有性能优势或其他什么?
我还注意到我的应用程序中的一些文件被编译成.pyc,而其他文件则没有,这是为什么?
当前回答
.pyc文件是已经编译为字节码的Python。如果Python发现一个.pyc文件与你调用的.py文件同名,它会自动运行一个.pyc文件。
《Python简介》是这样描述编译后的Python文件的:
程序不会运行得更快 它是从a '读过来的。Pyc '或'。pyo ' 文件比从' .py '读取时的文件 文件;这是唯一更快的方法 关于”。Pyc ' or '。Pyo '文件是 它们装载的速度。
运行.pyc文件的优点是Python不需要在运行它之前进行编译。由于Python会在运行.py文件之前编译为字节码,因此除此之外不应该有任何性能改进。
使用编译过的.pyc文件可以得到多大的改进?这取决于脚本的功能。对于只打印“Hello World”的非常简短的脚本,编译可能占启动和运行总时间的很大比例。但是对于长时间运行的脚本,相对于总运行时间,编译脚本的成本会减少。
您在命令行中命名的脚本永远不会保存到.pyc文件中。只有由“main”脚本加载的模块才会以这种方式保存。
其他回答
它被编译成字节码,使用起来非常非常快。
有些文件没有被编译的原因是,每次运行脚本时,你用python main.py调用的主脚本都会被重新编译。所有导入的脚本都将被编译并存储在磁盘上。
Ben Blank补充的重要内容:
值得注意的是,在运行 编译脚本启动速度更快 时间(因为它不需要时间 编译后),它不运行任何文件 得更快。
优点:
第一:温和的、可克服的困惑。
第二:如果编译生成的文件明显更小,那么加载时间就会更快。对网络来说很不错。
第三:Python可以跳过编译步骤。在初始负载时更快。这对CPU和网络来说都是好事。
第四:注释越多,.pyc或.pyo文件与源.py文件相比就越小。
第五:只有.pyc或.pyo文件的最终用户不太可能向您提供由他们忘记告诉您的未恢复更改引起的错误。
第六:如果您的目标是嵌入式系统,请获得较小的尺寸 要嵌入的文件可能代表着一个显著的优点,而且架构是稳定的,所以缺点之一(下面详细说明)没有发挥作用。
顶层编译
知道你可以用这种方式将顶级python源文件编译成.pyc文件是很有用的:
python -m py_compile myscript.py
这将删除注释。它保持文档字符串完整。如果你也想摆脱文档字符串(你可能想认真考虑为什么要这样做),那么就用这种方式编译…
python -OO -m py_compile myscript.py
...你会得到一个。pyo文件而不是。pyc文件;就代码的基本功能而言,它具有同样的可分发性,但从剥离出来的文档字符串的大小来看更小(如果一开始就有像样的文档字符串,那么后续的工作就不那么容易理解)。但请看下面的缺点三。
请注意,python使用。py文件的日期,如果它存在,来决定是否应该执行.py文件而不是.pyc或.pyo文件——所以编辑你的.py文件,.pyc或.pyo将被淘汰,你所获得的任何好处都将失去。您需要重新编译它,以便再次获得.pyc或.pyo的好处。
缺点:
首先:在.pyc和.pyo文件中有一个“神奇的cookie”,它指示编译python文件的系统体系结构。如果您将其中一个文件分发到不同类型的环境中,它就会崩溃。如果你分发的.pyc或.pyo没有相关的.py来重新编译或修改,因此它取代了.pyc或.pyo,最终用户也无法修复它。
第二:如果使用如上所述的-OO命令行选项跳过文档字符串,则没有人能够获得该信息,这可能会使代码的使用更加困难(或不可能)。
第三:Python的-OO选项也根据-O命令行选项实现了一些优化;这可能会导致操作上的变化。已知的优化有:
Sys.flags.optimize = 1 Assert语句被跳过 __debug__ = False
第四:如果你故意让你的python脚本使用#!/usr/bin/python在第一行,这将被剥离到.pyc和.pyo文件中,该功能将丢失。
第五:使用选项-O和-OO,断言语句不会被编译,从而消除了运行时验证的来源。您可以使用try except来弥补这一点,但这需要放弃assert语句,以便在将要编译的任何内容中使用。
第六:有些明显,但如果你编译你的代码,不仅它的使用会受到影响,而且其他人从你的工作中学习的潜力也会减少,通常是严重的。
是的,性能是主要原因,据我所知,也是唯一的原因。
如果您的一些文件没有被编译,可能是因为目录权限或其他原因,Python无法写入.pyc文件。或者可能未编译的文件从来没有被加载……(脚本/模块只有在第一次加载时才会被编译)
没有涉及到的是源到源的编译。例如,nuitka将Python代码转换为C/ c++,并将其编译为直接在CPU上运行的二进制代码,而不是在较慢的虚拟机上运行的Python字节码。
这可以显著提高速度,或者当您的环境依赖于C/ c++代码时,它可以让您使用Python。
.pyc文件是已经编译为字节码的Python。如果Python发现一个.pyc文件与你调用的.py文件同名,它会自动运行一个.pyc文件。
《Python简介》是这样描述编译后的Python文件的:
程序不会运行得更快 它是从a '读过来的。Pyc '或'。pyo ' 文件比从' .py '读取时的文件 文件;这是唯一更快的方法 关于”。Pyc ' or '。Pyo '文件是 它们装载的速度。
运行.pyc文件的优点是Python不需要在运行它之前进行编译。由于Python会在运行.py文件之前编译为字节码,因此除此之外不应该有任何性能改进。
使用编译过的.pyc文件可以得到多大的改进?这取决于脚本的功能。对于只打印“Hello World”的非常简短的脚本,编译可能占启动和运行总时间的很大比例。但是对于长时间运行的脚本,相对于总运行时间,编译脚本的成本会减少。
您在命令行中命名的脚本永远不会保存到.pyc文件中。只有由“main”脚本加载的模块才会以这种方式保存。