python文件hello.py
#a = 1
#b = 2
def add(a=1, b=2):
c = a + b
print(c)
return c
if __name__ == '__main__':
add()
# print(c) #doesnot work
c++文件test.cpp
#include <Python.h>
#include<iostream>
using namespace std;
int main()
{
Py_Initialize();//使用python之前,要调用Py_Initialize();这个函数进行初始化
if (!Py_IsInitialized())
{
printf("初始化失败!");
return 0;
}
PyRun_SimpleString("import sys");
PyRun_SimpleString("sys.path.append('./')");//这一步很重要,修改Python路径,不正确的话会出现 没找到 的情况。
PyObject * pModule = NULL;//声明变量
PyObject * pFunc = NULL;// 声明变量
pModule = PyImport_ImportModule("hello");//这里是要调用的文件名hello.py
if (pModule == NULL)
{
cout << "没找到" << endl;
}
pFunc = PyObject_GetAttrString(pModule, "add");//这里是要调用的函数名
PyObject* args = Py_BuildValue("(ii)", 2, 3);//给python函数参数赋值
// PyObject* pRet = PyObject_CallObject(pFunc,NULL);//直接用python程序的默认参数
PyObject_CallObject(pFunc, args);//调用函数,不设返回值,利用python程序进行输出
// PyObject* pRet = PyObject_CallObject(pFunc, args);//调用函数,c++进行输出
// int res = 0;
// PyArg_Parse(pRet, "i", &res);//转换返回类型
// cout << "res:" << res << endl;//输出结果
Py_Finalize();//调用Py_Finalize,这个跟Py_Initialize相对应的。
return 0;
}
Makefile文件
EXEC=test
OBJDIR=./obj/
CPP=g++
LDFLAGS= -L/usr/lib/x86_64-linux-gnu/ -lm -lboost_system -lboost_thread -ldl -std=c++11
COMMON+= `pkg-config opencv --libs --cflags opencv`
COMMON+= -I /usr/include/python3.5
CFLAGS+= -L/usr/local/lib -L/usr/lib/python3.5/config-3.5m-x86_64-linux-gnu -lpython3.5
OBJ=test.o
OBJS = $(addprefix $(OBJDIR), $(OBJ))
all: obj $(EXEC)
$(EXEC): $(OBJS)
$(CPP) $^ -o $@ $(COMMON) $(LDFLAGS) $(CFLAGS)
$(OBJDIR)%.o: %.cpp
$(CPP) $(COMMON) $(LDFLAGS) $(CFLAGS) -c $< -o $@
obj:
mkdir -p obj
.PHONY: clean
clean:
rm -rf $(OBJS) $(EXEC)
编译成功后即可测试运行,但是我修改Makefile文件后,用c++调用anaconda环境下的python一直没有成功,有人帮忙解答吗?