如何生成pyc/pyo/pyd文件

# 一.如何生成pyc/pyo文件

# 1.通过编写代码生成
import py_compile
# 参数如下
‘‘‘
def compile(file, cfile=None, dfile=None, doraise=False, optimize=-1):
    file:要编译的源文件
    cfile:编译之后的pyc文件路径和文件名,默认直接在file后面加上c或者o(会保存在当前目录的__pycache__文件夹下),
           pyo相当于优化之后的pyc
    dfile:把在错误信息中显示的file用dfile替换
    doraise:True或False,如果为True,那么文件编译出错的话,则会引发一个PyCompileError。
            为False的话,编译出错会显示在sys.stderr中
    optimize:用于编译的优化级别,有效的值为-1,0,1,2。-1表示当前解释器的优化级别
              使用命令行的时候如果设置优化级别,通过-O来设置。用于生成pyo文件了。
说白了后面几个参数基本上用不到
‘‘‘
py_compile.compile("your_py_file")

# 2.通过命令行生成
# python (-O) -m py_compile your_py_file.py   ,加上-O表示优化

‘‘‘
有的时候我们不想只编译一个py文件,而是编译一个文件夹下的所有py文件怎么办呢?
python还为我们提供了一个模块
‘‘‘
import compileall
# 参数如下
‘‘‘
def compile_dir(dir, maxlevels=10, ddir=None, force=False, rx=None,
                quiet=0, legacy=False, optimize=-1, workers=1):
dir:文件夹路径
maxlevels:递归编译的的子目录的层数,默认是把10层子目录的py文件编译成pyc
ddir:和上面的dfile类似
force:如果为True,将强制编译为pyc,即便现在pyc文件是最新的,依旧会编译一次
rx:一个正则表达式,可以排除掉不想编译的目录,只编译想要的目录
quiet:给我安静点,编译之后不会在标准输出中,打印信息
‘‘‘
compileall.compile_dir("your_dir")

# 同样可以使用命令行
# python -m compileall your_dir

  我们来编译一个试试

 首先我在foo.py中定义了一个函数fuck,然后在bar.py中进行编译,这里就不使用命令行了,效果是一样的。

会发现在当前目录下的__pycache__目录中多出了一个文件,正是刚才对编译的字节码文件。我们把它移动到当前目录来,并把foo.py删除,并把名字改一下,否则无法导入

 发现依旧执行成功了,py文件和pyc文件可以按照相同的方式导入

--------------------------------------------------------------------

原文地址:https://www.cnblogs.com/traditional/p/9738496.html

时间: 2024-10-02 20:43:49

如何生成pyc/pyo/pyd文件的相关文章

Python文件格式 .py .pyc .pyw .pyo .pyd的主要区别

Python是一种面向对象.解释型计算机程序设计语言.Python 语法简洁.清晰,具有丰富和强大的类库.Python源代码遵循 GPL (GNU General Public License) 协议,由 Guido van Rossum 于 1989 年底发明,第一个公开发行版发行于 1991 年.Python 常被称为胶水语言,能把用其他语言编写的各模块 (尤其是 C/C++) 轻松地联结在一起.常见情形是,用 Python 快速生成程序原型 (有时甚至是程序最终界面),然后对其中有特别要求

python 文件 .py .pyc .pyw .pyo .pyd

DLL文件即动态链接库文件,是一种可执行文件,它允许程序共享执行特殊任务所必需的代码和其他资源.打不开,不过可以使用反汇编;PYD是一种PYTHON动态模块.实质上还是dll文件,只是改了后缀为PYD,pyd: 扩展模块,一般用C或C++编写,其实可以说是一种更优秀的D语言编写的. 源自:http://my.oschina.net/renwofei423/blog/17404 通常认为,Python是一种解释性的语言,但是这种说法是不正确的,实际上,Python在执行时,首先会将.py文件中的源

Python生成pyd文件

Python的脚本文件是开源的,量化策略的安全性没有保障.因此需要保护源码.那么要对Python代码进行混淆.加密保护. 混淆代码,我准备使用pyminifier.而加密处理,就比较麻烦. Python有py.pyc.pyw.pyo.pyd等文件格式. 其中,pyc是二进制文件.但很容易被反编译. pyw也不行,只是隐藏命令行界面而已,可以作为入口脚本. pyo和pyc差不多,也容易被反编译. 最后剩下pyd格式.pyd格式是D语言(C/C++综合进化版本)生成的二进制文件,实际也会是dll文件

Python生成pyc文件

pyc文件是py文件编译后生成的字节码文件(byte code).pyc文件经过Python解释器最终会生成机器码运行 为什么要手动提前生成pyc文件呢,主要是不想把源代码暴露出来. python -m foo.py    #生成单个pyc文件

rpm打包时包含python脚本,需要忽略掉pyc, pyo字节码文件

制作rpm包时,有时包含python程序,一般默认的行为:打包时对python脚本会编译成pyc,pyo字节码文件并一起放在rpm包中,这可能导致打包时引用文件缺失的错误. 如果不需要这些字节码文件,可以修改 /usr/lib/rpm/brp-python-bytecompile 找到编译pyc,pyo的两条命令,并将其注释,或者直接在脚本开头就用exit 0 退出. 但是要注意,如果已经打了一次包并在pyc,pyo文件缺失的步骤上失败,则打包的临时目录中可能残留了文件,需要把临时目录(通常在/

zg手册 之 python2.7.7源码分析(4)-- pyc字节码文件

什么是字节码 python解释器在执行python脚本文件时,对文件中的python源代码进行编译,编译的结果就是byte code(字节码) python虚拟机执行编译好的字节码,完成程序的运行 python会为导入的模块创建字节码文件 字节码文件的创建过程 当a.py依赖b.py时,如在a.py中import b python先检查是否有b.pyc文件(字节码文件),如果有,并且修改时间比b.py晚,就直接调用b.pyc 否则编译b.py生成b.pyc,然后加载新生成的字节码文件 字节码对象

如何重新生成PostgreSQL的国际化文件

首先,必须在编译前指定 --enable-nls="语言名",否则不会产生多语言支持,比如 --enable-nls="zh_CN" 当然禁用nls会带来一点微不足道的性能提升 启用之后我们在 Makefile.global 中会看到: enable_nls = yes ... ifeq ($(enable_nls), yes) ifneq (,$(wildcard $(srcdir)/nls.mk)) include $(top_srcdir)/src/nls-g

Java生成和操作Excel文件

JAVA EXCEL API:是一开放源码项目,通过它Java开发人员可以读取Excel文件的内容.创建新的Excel文件.更新已经存在的Excel文件.使用该API非Windows操作系统也可以通过纯Java应用来处理Excel数据表.因为它是使用Java编写的,所以我们在Web应用中可以通过JSP.Servlet来调用API实现对Excel数据表的访问. 下载: 官方网站 http://www.andykhan.com/jexcelapi/ 下载最新版本(本人下的是jexcelapi_2_6

图文介绍MyEclipse (2015) 中创建简单的Maven项目的步骤(用于生成可运行jar文件)

利用MyEclipse的引导,能够非常方便的创建简单的.用于生成可运行jar文件的Maven项目: (原创文章,转载请注明转自Clement-Xu的博客:http://blog.csdn.net/clementad/article/details/46954277) 1.New -> Project... 选择 Maven Project, 点击Next > 2.在Select projrect name and location界面,各选项例如以下图,点击Next > 3.在Selec