在使用Cython编译项目时
简单例子:创建myconfig.py和setup.py,其中myconfig.py是自己已完成,想要编译的python脚本,setup.py是使用Cython的编译脚本。
# file: setup.py
from distutils.core import setup
from Cython.Build import cythonize
setup(name='myconfig',
ext_modules=cythonize("myconfig.py"))
运行如下:
python setup.py build_ext --inplace
运行过程中发现有警告,警告如下:
myconfig.c: 在函数‘__pyx_pw_18lims_report_upload_8myconfig_11initConfig’中:
myconfig.c:6326: 警告:dereferencing pointer ‘func.897’ does break strict-aliasing rules
myconfig.c:6326: 附注:initialized from here
myconfig.c:6292: 警告:dereferencing pointer ‘func.888’ does break strict-aliasing rules
myconfig.c:6292: 附注:initialized from here
myconfig.c:6293: 警告:dereferencing pointer ‘func.888’ does break strict-aliasing rules
myconfig.c:6293: 附注:initialized from here
.......
虽然有警告,但是也可调用生成的.so文件,但是毕竟有警告,所以查找一些资料说是gcc版本的问题,但是应该是此种方法适用cython编写的流程(.pyx),不适用在纯python脚本编译(自己猜测)。
最终是采用手动gcc编译通过的,代码如下:
cython myconfig.py --embed -3
gcc -fPIC -shared -I/省略路径/miniconda3/include/python3.7m/ myconfig.c -o myconfig.so
此方法生成的.so文件没有警告,也可调用.so文件。
cython myconfig.{py,pyx} --embed -3是将myconfig.{pyx,py}编译成.c文件,其中 --embed参数生成一个main()函数,该函数嵌入Python解释器;-3是基于Python-3语法和代码语义进行编译,若是python2,则使用-2参数;然后使用gcc编译成.so文件供python脚本import调用,若是python2,gcc中换成python2的头文件。
最终脚本中只保留.so就可以被python import调用了,这样就做到了对python脚本的加密。