当前位置:编程学习 > C/C++ >>

c++与Python3互相调用

由于最近想看看动态语言,所以就看了下python的使用方法,但是有时候动态语言的执行效率是个问题,于是就想,如何利用静态语言和动态语言进行结合,由于本人比较水,只会写一些c++,所以就决定用c++和python进行互调,但是网上都是python2和c++的调用,没有python3的互相调用的例子,windows下就更少了,于是我自己摸索了一晚上,终于把python和c++互调研究通了。

 
[cpp]
<SPAN style="FONT-SIZE: 18px">#include <Python.h> 
#include <string>  
#include <codecvt>  
int main(int argc, char** argv) 

    // 初始化Python  
    //在使用Python系统前,必须使用Py_Initialize对其  
    //进行初始化。它会载入Python的内建模块并添加系统路  
    //径到模块搜索路径中。这个函数没有返回值,检查系统  
    //是否初始化成功需要使用Py_IsInitialized。  
  
    Py_Initialize(); 
  
    // 检查初始化是否成功  
    if ( !Py_IsInitialized() ) 
    { 
        return -1; 
    } 
  
    // 添加当前路径  
    //把输入的字符串作为Python代码直接运行,返回0  
    //表示成功,-1表示有错。大多时候错误都是因为字符串  
    //中有语法错误。  
    PyRun_SimpleString("print(4+5)"); 
    PyRun_SimpleString("import sys"); 
    PyRun_SimpleString("sys.path.append('G:/pythonProject')"); 
    PyObject *pName,*pModule,*pDict,*pFunc,*pArgs,*pValue; 
  
  
    <SPAN style="COLOR: #ff0000">std::wstring str = L"pytest"; 
  
    std::wstring_convert<std::codecvt_utf8<wchar_t>> conv; 
  
    std::string  sr= conv.to_bytes(str); 
    // 载入名为pytest的脚本  
    pName = PyUnicode_FromUnicode(str.c_str(),str.size()); 
  
    //pName = PyString_FromString("pytest");  
    pModule = PyImport_ImportModule(sr.c_str()); 
      
    //pModule = PyImport_Import(pName);</SPAN>  
    if (!pModule) 
    { 
        printf("can't find pytest.py"); 
        getchar(); 
        return -1; 
    } 
    pDict = PyModule_GetDict(pModule); 
    if ( !pDict ) 
    { 
        return -1; 
    } 
  
    // 找出函数名为add的函数  
    pFunc = PyDict_GetItemString(pDict, "add"); 
    if ( !pFunc || !PyCallable_Check(pFunc) ) 
    { 
        printf("can't find function [add]"); 
        getchar(); 
        return -1; 
    } 
  
    // 参数进栈  
    pArgs = PyTuple_New(2); 
  
    //  PyObject* Py_BuildValue(char *format, ...)  
    //  把C++的变量转换成一个Python对象。当需要从  
    //  C++传递变量到Python时,就会使用这个函数。此函数  
    //  有点类似C的printf,但格式不同。常用的格式有  
    //  s 表示字符串,  
    //  i 表示整型变量,  
    //  f 表示浮点数,  
    //  O 表示一个Python对象。  
  
    PyTuple_SetItem(pArgs, 0, Py_BuildValue("l",3)); 
    PyTuple_SetItem(pArgs, 1, Py_BuildValue("l",4)); 
  
    // 调用Python函数  
    PyObject_CallObject(pFunc, pArgs); 
  
    //下面这段是查找函数foo 并执行foo  
    pFunc = PyDict_GetItemString(pDict, "foo"); 
    if ( !pFunc || !PyCallable_Check(pFunc) ) 
    { 
        printf("can't find function [foo]"); 
        getchar(); 
        return -1; 
    } 
  
    pArgs = PyTuple_New(1); 
    PyTuple_SetItem(pArgs, 0, Py_BuildValue("l",2)); //  
  
    PyObject_CallObject(pFunc, pArgs); 
  
  
    Py_DECREF(pName); 
    Py_DECREF(pArgs); 
    Py_DECREF(pModule); 
  
    // 关闭Python  
    Py_Finalize(); 
  
    system("pause"); 
    return 0; 
}</SPAN> 

#include <Python.h>
#include <string>
#include <codecvt>
int main(int argc, char** argv)
{
    // 初始化Python
    //在使用Python系统前,必须使用Py_Initialize对其
    //进行初始化。它会载入Python的内建模块并添加系统路
    //径到模块搜索路径中。这个函数没有返回值,检查系统
    //是否初始化成功需要使用Py_IsInitialized。
 
    Py_Initialize();
 
    // 检查初始化是否成功
    if ( !Py_IsInitialized() )
    {
        return -1;
    }
 
    // 添加当前路径
    //把输入的字符串作为Python代码直接运行,返回0
    //表示成功,-1表示有错。大多时候错误都是因为字符串
    //中有语法错误。
    PyRun_SimpleString("print(4+5)");
    PyRun_SimpleString("import sys");
    PyRun_SimpleString("sys.path.append('G:/pythonProject')");
    PyObject *pName,*pModule,*pDict,*pFunc,*pArgs,*pValue;
 
 
    std::wstring str = L"pytest";
 
    std::wstring_convert<std::codecvt_utf8<wchar_t>> conv;
 
    std::string  sr= conv.to_bytes(str);
    // 载入名为pytest的脚本
    pName = PyUnicode_FromUnicode(str.c_str(),str.size());
补充:软件开发 , C++ ,

CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,