用C语言实现python的扩展模块

简介:
用C语言实现python的扩展模块
示例1:
1    Example.c
int add(int a,int b)
{
        return a+b;
}

int sub(int a,int b)
{
        return a -b;
}

int mul(int a,int b)
{
        return a*b;
}

int div1(int a,int b)
{
        if(0 == b)
        {
                return b;
        }
        return a/b;
}
2  wrap.c
#include <Python.h> //python.h中已经包含了常用的头文件
PyObject* wrap_add(PyObject* self, PyObject* args)
{
  int n1,n2, result;
 
  if (! PyArg_ParseTuple(args, "i|i", &n1,&n2))
    return NULL;
  result = add(n1,n2);
  return Py_BuildValue("i", result);
}

PyObject* wrap_sub(PyObject* self, PyObject* args)
{
  int n1,n2, result;
 
  if (! PyArg_ParseTuple(args, "i|i", &n1,&n2))
    return NULL;
  result = sub(n1,n2);
  return Py_BuildValue("i", result);
}

PyObject* wrap_mul(PyObject* self, PyObject* args)
{
  int n1,n2, result;
 
  if (! PyArg_ParseTuple(args, "i|i", &n1,&n2))
    return NULL;
  result = mul(n1,n2);
  return Py_BuildValue("i", result);
}
PyObject* wrap_div1(PyObject* self, PyObject* args)
{
  int n1,n2, result;
  if (! PyArg_ParseTuple(args, "i|i", &n1,&n2))
    return NULL;
  result = div1(n1,n2);
  return Py_BuildValue("i", result);
}


static PyMethodDef exampleMethods[] =
{
  {"add", wrap_add, METH_VARARGS, "Caculate 1!"},
  {"sub", wrap_sub, METH_VARARGS, "Caculate 2!"},
  {"mul", wrap_mul, METH_VARARGS, "Caculate 3!"},
  {"div1", wrap_div1, METH_VARARGS, "Caculate 4!"},
  {NULL, NULL,0,NULL}
};

void initexample()
{
  PyObject* m;
  m = Py_InitModule("example", exampleMethods);
}
3 编译
gcc -fpic -c -I /usr/include/python2.6/ -I /usr/lib/python2.6/config example.c wrap.c
gcc -shared -o wrap.so  wrap.o
4 功能演示截图
 
5  主要参考:
5.1    Python的C语言扩展
http://www.ibm.com/developerworks/cn/linux/l-pythc/
5.2  浅谈 Python 程序和 C 程序的整合
http://www.ibm.com/developerworks/cn/linux/l-cn-pythonandc/index.html?ca=drs-cn-0506

示例2:(支持回调python中定义的函数)
1  mytest.c
#include <Python.h>
static PyObject *my_callback = NULL;
static PyObject* my_strlen(PyObject *self, PyObject *args)
{
   char *string;
   int len;
   if (!PyArg_ParseTuple(args, "s", &string))

     return NULL;
   len = strlen(string);
   return Py_BuildValue("i", len);
}

static PyObject* my_strcat(PyObject *self, PyObject *args)
{
    char* string1;
    char* string2;
    char* newstring;

    if (!PyArg_ParseTuple(args, "s|s", &string1, &string2))
        return NULL;
    newstring = strcat(string1, string2);
    return Py_BuildValue("s", newstring);
}

static PyObject* my_set_callback(PyObject *self, PyObject *args)
{
    PyObject *result = NULL;
    PyObject *temp;

    if (PyArg_ParseTuple(args, "O", &temp))
    {
         if (!PyCallable_Check(temp))
        {
              PyErr_SetString(PyExc_TypeError, "parameter must be callable");
              return NULL;
         }
     Py_XINCREF(temp);
     Py_XDECREF(my_callback);
     my_callback = temp;

     Py_INCREF(Py_None);
     result = Py_None;
   }
   return result;
}
static PyObject* my_test_callback(PyObject *self, PyObject *args)
{
    PyObject * arglist;
    PyObject * result = NULL;

    result = PyEval_CallObject(my_callback, args);
    if (result == NULL)
    {
        return NULL;
    }
    Py_DECREF(result);
    Py_INCREF(Py_None);
    return Py_None;
}

static PyMethodDef mytestMethods[] =
{
     {"mystrlen", my_strlen, METH_VARARGS, "We test strlen of C"},
     {"mystrcat", my_strcat, METH_VARARGS, "We test strcat of C"},
     {"mysetcallback", my_set_callback, METH_VARARGS, "we set a call back function so that call it in C"},
     {"mytestcallback", my_test_callback, METH_VARARGS, "we use this function to test call back function"},
     {NULL, NULL, 0, NULL}
};

void initmytest()
{
      (void) Py_InitModule("mytest", mytestMethods);
}
2  编译
gcc -fpic -c -I /usr/include/python2.6/ -I /usr/lib/python2.6/config   mytest.c
gcc -shared -o mytest.so  mytest.o
3 功能演示截图
 
4 主要参考
4.1 . Calling Python Functions from C
4.2 在windows上扩展python
http://blog.chinaunix.net/space.php?uid=46552&do=blog&id=2116527
4.3 [精华] 在windows上扩展python(2)--从c中调用python函数
http://www.linuxforum.net/forum/gshowthreaded.php?Cat=&Board=python&Number=485550&page=3&view=collapsed&sb=5&o=all&vc=1



目录
相关文章
|
17天前
|
开发者 Python
如何在Python中管理模块和包的依赖关系?
在实际开发中,通常会结合多种方法来管理模块和包的依赖关系,以确保项目的顺利进行和可维护性。同时,要及时更新和解决依赖冲突等问题,以保证代码的稳定性和可靠性
33 4
|
15天前
|
算法 数据安全/隐私保护 开发者
马特赛特旋转算法:Python的随机模块背后的力量
马特赛特旋转算法是Python `random`模块的核心,由松本真和西村拓士于1997年提出。它基于线性反馈移位寄存器,具有超长周期和高维均匀性,适用于模拟、密码学等领域。Python中通过设置种子值初始化状态数组,经状态更新和输出提取生成随机数,代码简单高效。
101 63
|
17天前
|
测试技术 Python
手动解决Python模块和包依赖冲突的具体步骤是什么?
需要注意的是,手动解决依赖冲突可能需要一定的时间和经验,并且需要谨慎操作,避免引入新的问题。在实际操作中,还可以结合使用其他方法,如虚拟环境等,来更好地管理和解决依赖冲突😉。
|
17天前
|
持续交付 Python
如何在Python中自动解决模块和包的依赖冲突?
完全自动解决所有依赖冲突可能并不总是可行,特别是在复杂的项目中。有时候仍然需要人工干预和判断。自动解决的方法主要是提供辅助和便捷,但不能完全替代人工的分析和决策😉。
|
23天前
|
JSON Linux 数据格式
Python模块:从入门到精通,只需一篇文章!
Python中的模块是将相关代码组织在一起的单元,便于重用和维护。模块可以是Python文件或C/C++扩展,Python标准库中包含大量模块,如os、sys、time等,用于执行各种任务。定义模块只需创建.py文件并编写代码,导入模块使用import语句。此外,Python还支持自定义模块和包,以及虚拟环境来管理项目依赖。
Python模块:从入门到精通,只需一篇文章!
|
1天前
|
Unix 编译器 C语言
[oeasy]python052_[系统开发语言为什么默认是c语言
本文介绍了C语言为何成为系统开发的首选语言,从其诞生背景、发展历史及特点进行阐述。C语言源于贝尔实验室,与Unix操作系统相互促进,因其简洁、高效、跨平台等特性,逐渐成为主流。文章还提及了C语言的学习资料及其对编程文化的影响。
11 5
|
14天前
|
C语言 开发者
C语言中的模块化编程思想,介绍了模块化编程的概念、实现方式及其优势,强调了合理划分模块、明确接口、保持独立性和内聚性的实践技巧
本文深入探讨了C语言中的模块化编程思想,介绍了模块化编程的概念、实现方式及其优势,强调了合理划分模块、明确接口、保持独立性和内聚性的实践技巧,并通过案例分析展示了其应用,展望了未来的发展趋势,旨在帮助读者提升程序质量和开发效率。
26 5
|
17天前
|
Python
Python的模块和包
总之,模块和包是 Python 编程中非常重要的概念,掌握它们可以帮助我们更好地组织和管理代码,提高开发效率和代码质量
29 5
|
17天前
|
数据可视化 Python
如何在Python中解决模块和包的依赖冲突?
解决模块和包的依赖冲突需要综合运用多种方法,并且需要团队成员的共同努力和协作。通过合理的管理和解决冲突,可以提高项目的稳定性和可扩展性
|
21天前
|
JavaScript 前端开发 Python
python中的OS模块的基本使用
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。博客分享前端技术及全栈开发经验,持续更新中,期待您的关注和支持!🎉🎉🎉
28 0