源代码: Lib/py_compile.py
为民乐等地区用户提供了全套网页设计制作服务,及民乐网站建设行业解决方案。主营业务为网站设计制作、成都做网站、民乐网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
py_compile 模块提供了用来从源文件生成字节码的函数和另一个用于当模块源文件作为脚本被调用时的函数。
虽然不太常用,但这个函数在安装共享模块时还是很有用的,特别是当一些用户可能没有权限在包含源代码的目录中写字节码缓存文件时。
exception py_compile.PyCompileError
当编译文件过程中发生错误时,抛出的异常。
py_compile.compile(file, cfile=None, dfile=None, doraise=False, optimize=- 1, invalidation_mode=PycInvalidationMode.TIMESTAMP, quiet=0)
Compile a source file to byte-code and write out the byte-code cache file. The source code is loaded from the file named file. The byte-code is written to cfile, which defaults to the PEP 3147/PEP 488 path, ending in .pyc
. For example, if file is /foo/bar/baz.py
cfile will default to /foo/bar/__pycache__/baz.cpython-32.pyc
for Python 3.2. If dfile is specified, it is used instead of file as the name of the source file from which source lines are obtained for display in exception tracebacks. If doraise is true, a PyCompileError is raised when an error is encountered while compiling file. If doraise is false (the default), an error string is written to sys.stderr
, but no exception is raised. This function returns the path to byte-compiled file, i.e. whatever cfile value was used.
doraise 和 quiet 参数确定在编译文件时如何处理错误。 如果 quiet 为 0 或 1,并且 doraise 为假值,则会启用默认行为:写入错误信息到 sys.stderr
,并且函数将返回 None
而非一个路径。 如果 doraise 为真值,则将改为引发 PyCompileError。 但是如果 quiet 为 2,则不会写入消息,并且 doraise 也不会有效果。
如果 cfile 所表示(显式指定或计算得出)的路径为符号链接或非常规文件,则将引发 FileExistsError。 此行为是用来警告如果允许写入编译后字节码文件到这些路径则导入操作将会把它们转为常规文件。 这是使用文件重命名来将最终编译后字节码文件放置到位以防止并发文件写入问题的导入操作的附带效果。
optimize 控制优化级别并会被传给内置的 compile() 函数。 默认值 -1
表示选择当前解释器的优化级别。
invalidation_mode 应当是 PycInvalidationMode 枚举的成员,它控制在运行时如何让已生成的字节码缓存失效。 如果设置了 SOURCE_DATE_EPOCH
环境变量则默认值为 PycInvalidationMode.CHECKED_HASH,否则默认值为 PycInvalidationMode.TIMESTAMP。
在 3.2 版更改: 将 cfile 的默认值改成与 PEP 3147 兼容。 之前的默认值是 file + 'c'
(如果启用优化则为 'o'
)。 同时也添加了 optimize 形参。
在 3.4 版更改: 将代码更改为使用 importlib 执行字节码缓存文件写入。 这意味着文件创建/写入的语义现在与 importlib 所做的相匹配,例如权限、写入和移动语义等等。 同时也添加了当 cfile 为符号链接或非常规文件时引发 FileExistsError 的预警设置。
在 3.7 版更改: invalidation_mode 形参是根据 PEP 552 的描述添加的。 如果设置了 SOURCE_DATE_EPOCH
环境变量,invalidation_mode 将被强制设为 PycInvalidationMode.CHECKED_HASH。
在 3.7.2 版更改: SOURCE_DATE_EPOCH
环境变量不会再覆盖 invalidation_mode 参数的值,而改为确定其默认值。
在 3.8 版更改: 增加了 quiet 形参。
class py_compile.PycInvalidationMode
一个由可用方法组成的枚举,解释器可以用来确定字节码文件是否与源文件保持一致。 .pyc
文件在其标头中指明了所需的失效模式。 请参阅 已缓存字节码的失效 了解有关 Python 在运行时如何让 .pyc
文件失效的更多信息。
3.7 新版功能.
TIMESTAMP
.pyc
文件包括时间戳和源文件的大小,Python 将在运行时将其与源文件的元数据进行比较以确定 .pyc
文件是否需要重新生成。
CHECKED_HASH
.pyc
文件包括源文件内容的哈希值,Python 将在运行时将其与源文件内容进行比较以确定 .pyc
文件是否需要重新生成。
UNCHECKED_HASH
类似于 CHECKED_HASH,.pyc
文件包括源文件内容的哈希值。 但是,Python 将在运行时假定 .pyc
文件是最新的而完全不会将 .pyc
与源文件进行验证。
此选项适用于 .pycs
由 Python 以外的某个系统例如构建系统来确保最新的情况。
这个模块可作为脚本发起调用以编译多个源文件。 在 filenames 中指定的文件会被编译并将结果字节码以普通方式进行缓存。 这个程序不会搜索目录结构来定位源文件;它只编译显式指定的文件。 如果某个文件无法被编译则退出状态为非零值。
-
位置参数是要编译的文件。 如果 -
是唯一的形参,则文件列表将从标准输入获取。
-q, —quiet
屏蔽错误输出。
在 3.2 版更改: 添加了对 -
的支持。
在 3.10 版更改: 添加了对 -q 的支持。
参见
模块 compileall
编译一个目录树中所有 Python 源文件的工具。
本文题目:创新互联Python教程:py_compile—-编译Python源文件
当前地址:http://www.mswzjz.cn/qtweb/news49/523199.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能