由於最近想看看動態語言,所以就看了下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());
//pName = PyString_FromString("pytest");
pModule = PyImport_ImportModule(sr.c_str());
//pModule = PyImport_Import(pName);
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;
}同樣附上python代碼:
[python]
<PRE class=cpp name="code"><SPAN style="FONT-SIZE: 14px">def add(a,b):
print ("in python function add")
print ("a = " + str(a))
print ("b = " + str(b))
print ("ret = " + str(a+b))
return
def foo(a):
print ("in python function foo")
print ("a = " + str(a))
print ("ret = " + str(a * a))
return </SPAN></PRE><BR>
<BR>
<PRE></PRE>
<P></P>
<P><SPAN style="FONT-SIZE: 18px"></SPAN></P>
<P><SPAN style="FONT-SIZE: 18px">當然我也是從網上,c++和python2互相調用的文章中拿過來的,糾結本人的地方我已經用紅字標出來了,歡迎大家拍磚!<IMG alt=大笑 src=http://www.bkjia.com/uploads/allimg/131127/141S95Y0-0.gif"></SPAN></P>
<PRE></PRE>
[cpp] view plaincopyprint?<SPAN style="FONT-SIZE: 14px">def add(a,b): print ("in python function add") print ("a = " + str(a)) print ("b = " + str(b)) print ("ret = " + str(a+b)) return def foo(a): print ("in python function foo") print ("a = " + str(a)) print ("ret = " + str(a * a)) return </SPAN> def add(a,b):
print ("in python function add")
print ("a = " + str(a))
print ("b = " + str(b))
print ("ret = " + str(a+b))
return
def foo(a):
print ("in python function foo")
print ("a = " + str(a))
print ("ret = " + str(a * a))
return
當然我也是從網上,c++和python2互相調用的文章中拿過來的,糾結本人的地方我已經用紅字標出來了,歡迎大家拍磚!