Поиск…


Hello World с расширением C

Следующий исходный файл C (который мы будем называть hello.c для демонстрационных целей) создает модуль расширения с именем hello который содержит одну функцию greet() :

#include <Python.h>
#include <stdio.h>

#if PY_MAJOR_VERSION >= 3
#define IS_PY3K
#endif

static PyObject *hello_greet(PyObject *self, PyObject *args)
{
    const char *input;
    if (!PyArg_ParseTuple(args, "s", &input)) {
        return NULL;
    }
    printf("%s", input);
    Py_RETURN_NONE;
}

static PyMethodDef HelloMethods[] = {
    { "greet", hello_greet, METH_VARARGS, "Greet the user" },
    { NULL, NULL, 0, NULL }
};

#ifdef IS_PY3K
static struct PyModuleDef hellomodule = {
    PyModuleDef_HEAD_INIT, "hello", NULL, -1, HelloMethods
};

PyMODINIT_FUNC PyInit_hello(void)
{
    return PyModule_Create(&hellomodule);
}
#else
PyMODINIT_FUNC inithello(void)
{
    (void) Py_InitModule("hello", HelloMethods);
}
#endif

Чтобы скомпилировать файл с помощью gcc компилятора, выполните следующую команду в своем любимом терминале:

gcc /path/to/your/file/hello.c -o /path/to/your/file/hello

Чтобы выполнить функцию greet() которую мы написали ранее, создайте файл в том же каталоге и назовите его hello.py

import hello          # imports the compiled library
hello.greet("Hello!") # runs the greet() function with "Hello!" as an argument

Передача открытого файла в C Расширения

Передайте открытый файловый объект из кода расширения Python в C.

Вы можете преобразовать файл в дескриптор целочисленного файла, используя функцию PyObject_AsFileDescriptor :

PyObject *fobj;
int fd = PyObject_AsFileDescriptor(fobj);
if (fd < 0){
    return NULL;
}

Чтобы преобразовать дескриптор целочисленного файла обратно в объект python, используйте PyFile_FromFd .

int fd; /* Existing file descriptor */
PyObject *fobj = PyFile_FromFd(fd, "filename","r",-1,NULL,NULL,NULL,1);

C Расширение Использование c ++ и Boost

Это основной пример расширения C с использованием C ++ и Boost .

Код C ++

Код на C ++ помещен в hello.cpp:

#include <boost/python/module.hpp>
#include <boost/python/list.hpp>
#include <boost/python/class.hpp>
#include <boost/python/def.hpp>

// Return a hello world string.
std::string get_hello_function()
{
   return "Hello world!";
}

// hello class that can return a list of count hello world strings.
class hello_class
{
public:

   // Taking the greeting message in the constructor.
   hello_class(std::string message) : _message(message) {}

   // Returns the message count times in a python list.
   boost::python::list as_list(int count)
   {
      boost::python::list res;
      for (int i = 0; i < count; ++i) {
         res.append(_message);
      }
      return res;
   }
   
private:
   std::string _message;
};


// Defining a python module naming it to "hello".
BOOST_PYTHON_MODULE(hello)
{
   // Here you declare what functions and classes that should be exposed on the module.

   // The get_hello_function exposed to python as a function.
   boost::python::def("get_hello", get_hello_function);

   // The hello_class exposed to python as a class.
   boost::python::class_<hello_class>("Hello", boost::python::init<std::string>())
      .def("as_list", &hello_class::as_list)
      ;   
}

Чтобы скомпилировать это в модуль python, вам понадобятся заголовки python и библиотеки boost. Этот пример был сделан на Ubuntu 12.04 с использованием python 3.4 и gcc. Boost поддерживается на многих платформах. В случае Ubuntu необходимые пакеты были установлены с использованием:

sudo apt-get install gcc libboost-dev libpython3.4-dev

Компиляция исходного файла в .so-файл, который впоследствии может быть импортирован как модуль, если он находится на пути python:

gcc -shared -o hello.so -fPIC -I/usr/include/python3.4 hello.cpp -lboost_python-py34 -lboost_system -l:libpython3.4m.so

Код python в файле example.py:

import hello

print(hello.get_hello())

h = hello.Hello("World hello!")
print(h.as_list(3))

Затем python3 example.py даст следующий результат:

Hello world!
['World hello!', 'World hello!', 'World hello!']


Modified text is an extract of the original Stack Overflow Documentation
Лицензировано согласно CC BY-SA 3.0
Не связан с Stack Overflow