python和C,我觉得这简直是无敌的组合啊。一般性的业务逻辑用python快速出模型,而碰到python运行缓慢的操作,则可以通过调用C编译好的链接库来完成。
在python3.2下,可以通过ctype模块单纯的访问C链接库,也可以通过传统方式访问。ctype模块固然方便,但若要求回调的话,还是得用传统方式操作。
今天查阅了官方manual和网上一些链接,感觉有些出处,在这写上一个3.2.2的简单程序:
编辑一个文件lzymodule.c
按官方命名方式,前面是模块名,后面是module.c
#include <Python.h> //必须先include Python.h,Python.h中包含了一些预编译宏,包括了一些stdlib.h之类的头文件
/* 将要调用的函数,我提出来了 */
long func1(long a, long b)
{
return a + b;
}
/* 方法名字命名规范是“模块名_方法名”,我这里的方法名是system */
static PyObject *
lzy_system(PyObject *self, PyObject *args)
{
const char *command;
long a, b;
int sts;
if (!PyArg_ParseTuple(args, "ii", &a, &b)) //读入两个整形参数,转成C类型
return NULL;
//sts = system(command);
sts = func1(a, b);
return PyLong_FromLong(sts); //返回前,需要转成PyObject类型
}
/* 定义模块中的方法 */
static PyMethodDef LzyMethods[] =
{
{"func", lzy_system, METH_VARARGS, "my first test function"}, //注意func是在python中调用的名字,这里应该取system才规范
{NULL, NULL, 0, NULL}
};
/* 定义模块 */
static struct PyModuleDef lzymodule =
{
PyModuleDef_HEAD_INIT,
"lzy",
NULL,
-1,
LzyMethods
};
/* 这个就相当于主函数了,命名一定要为“PyInit_模块名” */
PyMODINIT_FUNC PyInit_lzy(void)
{
return PyModule_Create(&lzymodule);
}
之后进行编译
gcc lzymodule.c -shared -I /usr/local/include/python3.2m/ -o lzy.so -fPIC
最后进入python,试试
import lzy
lzy.func(1, 230)
有疑问请跟帖。
注,不愿意gcc的话,试试这个
脚本
from distutils.core import setup, Extension
test_mod = Extension('lzy', sources = ['lzymodule.c'])
setup(name = 'lzy',
version = '1.0',
description = 'lzy test extension module',
ext_modules = [test_mod])
python setup.py build
python setup.py install