一、 介绍
python是一种高层级的,动态的,解释性的,易学的语言,但是其带来的副作用是,运行效率可能会比静态编译语言慢几个数量级。我们可以使用python调用外部接口的方式,极大的提高python的运行效率,cython正是一种可以为Python编写接口的语言。相当于Python做前端的计算,后台的运行就交给用c或者c++实现的这些动态库来完成了,效率相比之前快了很多,既拥有了Python的便捷,又拥有了静态语言的速度,实在是不亦乐乎!
cudf当然也注意到了这一点,所以就使用cython来为pandas写封装了,大大提升了数据分析的速度。那么既然cython这么神奇我们又怎么使用cython为Python编写接口呢?
二、三个小例子
conda install cython 安装cython,下面demo均在conda下使用。
1. 简单入门示例demo_simple
我们使用的类示例是一个矩形类,四个变量x0,y0,x1,y1代表矩形的变量位置,定义了构造函数,析构函数,提供了三个函数 int getArea(); void getSize(int* width, int* height); 和 void move(int dx, int dy);分别在 Rectangle.h和Rectangle.cpp中完成声明和编写。
同时我们可以看到有两个文件Rectangle.pxd和rect.pyx,他们的后缀名是不一样的,这类似于c++中的.h文件和.cpp文件,.pxd 文件中有 Cython 模块要包含的 Cython 声明 (或代码段)。.pxd文件可共享外部 C 语言声明,也能包含 C 编译器内联函数。可用 cimport 关键字将 .pxd 文件导入 .pyx 模块文件中。.pyx 文件是由 Cython 编程语言 “编写” 而成的 Python 扩展模块源代码文件。.pyx 文件类似于 C++ 语言的 .cpp 源代码文件,.pyx 文件中有 Cython 模块的源代码。不像 Python 语言可直接解释使用的 .py 文件,.pyx 文件必须先被编译成 .c或者.cpp 文件,再编译成 .pyd (Windows 平台) 或 .so (Linux 平台) 文件,才可作为模块 import 导入使用。
Rectangle.pxd文件内容如下:
# distutils: sources = Rectangle.cpp