文档章节

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

MtrS
 MtrS
发布于 2015/02/27 16:36
字数 595
阅读 92
收藏 5

用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

© 著作权归作者所有

共有 人打赏支持
上一篇: Django signal 信号
下一篇: Python C
MtrS
粉丝 32
博文 555
码字总数 352764
作品 0
榆林
私信 提问
C/C++ 和 Python混合编程

链接:https://www.zhihu.com/question/23003213/answer/56121859 来源:知乎 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。 #include int main(int argc, char *...

sirius_0
04/21
0
0
使用C++编写python扩展模块

简介 长话短说,这里说的扩展Python功能与直接用其它语言写一个动态链接库,然后让Python来调用有点不一样(虽然本质是一样的)。而是指使用Python本身提供的API,使用C++来对Python进行功能...

openthings
2015/01/21
0
0
0. Python3源码—编译

0.1. 整体架构 在最高的层次上,Python的整体架构可以分为三个主要的部分: 左:Python提供的大量的模块、库以及用户自定义的模块; 右:Python的运行时环境,包括对象/类型系统(Object/Ty...

whj0709
06/06
0
0
SylixOS Python扩展库开发

1 适用范围 本文档适用于希望使用基于SylixOS进行Python扩展库开发的用户。 2 SylixOS Python简介 Python是一门面向对象的解释型的脚本语言,Python具有丰富和强大的库。它常被昵称为胶水语言...

zhaotongch
09/03
0
0
Supporting Python 3——迁移python2的c扩展到python3

迁移C扩展 Python 3有很多在C语言API上的变化,包括在API中定义类和初妈化的模块。这意味着每一个C扩展为了能在Python 3 下运行需要进行修改。一些变化很简单而另一些不简单,但是因为2to3只...

在湖闻樟
2015/04/14
0
1

没有更多内容

加载失败,请刷新页面

加载更多

Java 源代码和 C 源代码的运行区别

与其他程序的执行方式和编译方式不同。 Java 源代码需要进行编译成字节码后在 Java 虚拟机上运行,这样 Java 程序能够保持独立性和跨平台功特性。 请参考下图。 https://www.cwiki.us/pages...

honeymose
今天
4
0
Apache限定目录解析PHP,限制user_agent,PHP相关的配置

Apache限定目录解析PHP 配置前访问upload/index.php [root@test-a ~]# curl -x192.168.77.139:80 'www.test.com/upload/index.php'This is upload diretory 配置,/usr/local/apache2.4/......

野雪球
今天
5
0
java.util.Concurrent.Exchanger源码

类图 源码: package java.util.concurrent;import java.util.concurrent.atomic.AtomicInteger;import java.util.concurrent.atomic.AtomicReference;import java.util.concurrent......

狼王黄师傅
今天
6
0
Kubernetes里的secret最基本的用法

Secret解决了密码、token、密钥等敏感数据的配置问题,使用Secret可以避免把这些敏感数据以明文的形式暴露到镜像或者Pod Spec中。 Secret可以以Volume或者环境变量的方式使用。 使用如下命令...

JerryWang_SAP
昨天
5
0
2018-11-20学习笔记

1. python数据类型: 给变量赋值什么样的值,变量就是什么样的类型 给变量赋值整数,变量就是整数类型 给变量赋值字符串,变量就是字符串类型 123 和“123”一样吗? 在python中 单引号 与双...

laoba
昨天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部