c++ 调用 python


1.   新建控制台程序

2.   属性配置




说明:python26_d.lib的获取方式参见上一篇文章。

3.  c++代码

  1. #include <iostream>  
  2. #include <Python.h>  
  3.   
  4. using namespace std;  
  5.   
  6. void HelloWorld();  
  7. void Add();  
  8. void TestTransferDict();  
  9. void TestClass();  
  10.   
  11. int main()  
  12. {  
  13. cout << "Starting Test..." << endl;  
  14.   
  15. cout << "HelloWorld()-------------" << endl;  
  16. HelloWorld();  
  17. cout << "Add()--------------------" << endl;  
  18. Add();  
  19. cout << "TestDict-----------------" << endl;  
  20. TestTransferDict();  
  21. cout << "TestClass----------------" << endl;  
  22. TestClass();  
  23.   
  24. system("pause");  
  25. return 0;  
  26. }  
  27.   
  28. //调用输出"Hello World"函数  
  29. void HelloWorld()  
  30. {  
  31. Py_Initialize();//使用python之前,要调用Py_Initialize();这个函数进行初始化  
  32. PyObject * pModule = NULL;//声明变量  
  33. PyObject * pFunc = NULL;//声明变量  
  34. pModule =PyImport_ImportModule("Test001");//这里是要调用的Python文件名  
  35. pFunc= PyObject_GetAttrString(pModule, "HelloWorld"); //这里是要调用的函数名  
  36. PyEval_CallObject(pFunc, NULL); //调用函数,NULL表示参数为空  
  37. Py_Finalize();//调用Py_Finalize,这个和Py_Initialize相对应的.  
  38. }  
  39.   
  40. //调用Add函数,传两个int型参数  
  41. void Add()  
  42. {  
  43. Py_Initialize();  
  44.   
  45. PyObject * pModule = NULL;  
  46. PyObject * pFunc = NULL;  
  47. pModule =PyImport_ImportModule("Test001");//Test001:Python文件名  
  48. pFunc= PyObject_GetAttrString(pModule,"add");//Add:Python文件中的函数名    //创建参数  
  49. PyObject *pArgs = PyTuple_New(2); //函数调用的参数传递均是以元组的形式打包的,2表示参数个数  
  50. PyTuple_SetItem(pArgs, 0, Py_BuildValue("i", 5));//0---序号i表示创建int型变量  
  51. PyTuple_SetItem(pArgs, 1, Py_BuildValue("i", 7));//1---序号//返回值  
  52. PyObject *pReturn = NULL;  
  53. pReturn = PyEval_CallObject(pFunc, pArgs);//调用函数  
  54. //将返回值转换为int类型  
  55. int result;  
  56. PyArg_Parse(pReturn, "i", &result);//i表示转换成int型变量  
  57. cout << "5+7 = " << result << endl;  
  58.   
  59. Py_Finalize();  
  60. }  
  61.   
  62. //参数传递的类型为字典  
  63. void TestTransferDict()  
  64. {  
  65. Py_Initialize();  
  66.   
  67. PyObject * pModule = NULL;  
  68. PyObject * pFunc = NULL;  
  69. pModule =PyImport_ImportModule("Test001");//Test001:Python文件名  
  70. pFunc= PyObject_GetAttrString(pModule, "TestDict"); //Add:Python文件中的函数名  
  71. //创建参数:  
  72. PyObject *pArgs = PyTuple_New(1);   
  73. PyObject *pDict = PyDict_New(); //创建字典类型变量  
  74. PyDict_SetItemString(pDict, "Name", Py_BuildValue("s""WangYao")); //往字典类型变量中填充数据  
  75. PyDict_SetItemString(pDict, "Age", Py_BuildValue("i", 25)); //往字典类型变量中填充数据  
  76. PyTuple_SetItem(pArgs, 0, pDict);//0---序号将字典类型变量添加到参数元组中  
  77. //返回值  
  78. PyObject *pReturn = NULL;  
  79. pReturn = PyEval_CallObject(pFunc, pArgs);//调用函数  
  80. //处理返回值:  
  81. int size = PyDict_Size(pReturn);  
  82. cout << "返回字典的大小为: " << size << endl;  
  83. PyObject *pNewAge = PyDict_GetItemString(pReturn, "Age");  
  84. int newAge;  
  85. PyArg_Parse(pNewAge, "i", &newAge);  
  86. cout << "True Age: " << newAge << endl;  
  87.   
  88. Py_Finalize();  
  89. }  
  90.   
  91. //测试类  
  92. void TestClass()  
  93. {  
  94. Py_Initialize();  
  95.   
  96. PyObject * pModule = NULL;  
  97. PyObject * pFunc = NULL;  
  98. pModule =PyImport_ImportModule("Test001");//Test001:Python文件名  
  99. pFunc= PyObject_GetAttrString(pModule, "TestDict"); //Add:Python文件中的函数名  
  100. //获取Person类  
  101. PyObject *pClassPerson = PyObject_GetAttrString(pModule, "Person");  
  102. //创建Person类的实例  
  103. PyObject *pInstancePerson = PyInstance_New(pClassPerson, NULL, NULL);  
  104. //调用方法  
  105. PyObject_CallMethod(pInstancePerson, "greet""s""Hello Kitty"); //s表示传递的是字符串,值为"Hello Kitty"  
  106.   
  107. Py_Finalize();  
  108. }  


4. python代码

[python]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. #Test001.py    
  2. def HelloWorld():    
  3.     print "Hello World"    
  4. def add(a, b):    
  5.     return a+b    
  6. def TestDict(dict):    
  7.     print dict    
  8.     dict["Age"] = 17    
  9.     return dict    
  10. class Person:    
  11.     def greet(self, greetStr):    
  12.         print greetStr    
  13. #print add(5,7)    
  14. #a = raw_input("Enter To Continue...")  



说明:以上代码来自http://www.cnblogs.com/Hisin/archive/2012/02/27/2370590.html,感谢原作者!

经过本人验证,代码完全正确。

注意:当python代码有错误时,PyImport_ImportModule函数返回NULL;

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
智慧校园整体解决方案是响应国家教育信息化政策,结合教育改革和技术创新的产物。该方案以物联网、大数据、人工智能和移动互联技术为基础,旨在打造一个安全、高效、互动且环保的教育环境。方案强调从数字化校园向智慧校园的转变,通过自动数据采集、智能分析和按需服务,实现校园业务的智能化管理。 方案的总体设计原则包括应用至上、分层设计和互联互通,确保系统能够满足不同用户角色的需求,并实现数据和资源的整合与共享。框架设计涵盖了校园安全、管理、教学、环境等多个方面,构建了一个全面的校园应用生态系统。这包括智慧安全系统、校园身份识别、智能排课及选课系统、智慧学习系统、精品录播教室方案等,以支持个性化学习和教学评估。 建设内容突出了智慧安全和智慧管理的重要性。智慧安全管理通过分布式录播系统和紧急预案一键启动功能,增强校园安全预警和事件响应能力。智慧管理系统则利用物联网技术,实现人员和设备的智能管理,提高校园运营效率。 智慧教学部分,方案提供了智慧学习系统和精品录播教室方案,支持专业级学习硬件和智能化网络管理,促进个性化学习和教学资源的高效利用。同时,教学质量评估中心和资源应用平台的建设,旨在提升教学评估的科学性和教育资源的共享性。 智慧环境建设则侧重于基于物联网的设备管理,通过智慧教室管理系统实现教室环境的智能控制和能效管理,打造绿色、节能的校园环境。电子班牌和校园信息发布系统的建设,将作为智慧校园的核心和入口,提供教务、一卡通、图书馆等系统的集成信息。 总体而言,智慧校园整体解决方案通过集成先进技术,不仅提升了校园的信息化水平,而且优化了教学和管理流程,为学生、教师和家长提供了更加便捷、个性化的教育体验。
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
智慧校园整体解决方案是响应国家教育信息化政策,结合教育改革和技术创新的产物。该方案以物联网、大数据、人工智能和移动互联技术为基础,旨在打造一个安全、高效、互动且环保的教育环境。方案强调从数字化校园向智慧校园的转变,通过自动数据采集、智能分析和按需服务,实现校园业务的智能化管理。 方案的总体设计原则包括应用至上、分层设计和互联互通,确保系统能够满足不同用户角色的需求,并实现数据和资源的整合与共享。框架设计涵盖了校园安全、管理、教学、环境等多个方面,构建了一个全面的校园应用生态系统。这包括智慧安全系统、校园身份识别、智能排课及选课系统、智慧学习系统、精品录播教室方案等,以支持个性化学习和教学评估。 建设内容突出了智慧安全和智慧管理的重要性。智慧安全管理通过分布式录播系统和紧急预案一键启动功能,增强校园安全预警和事件响应能力。智慧管理系统则利用物联网技术,实现人员和设备的智能管理,提高校园运营效率。 智慧教学部分,方案提供了智慧学习系统和精品录播教室方案,支持专业级学习硬件和智能化网络管理,促进个性化学习和教学资源的高效利用。同时,教学质量评估中心和资源应用平台的建设,旨在提升教学评估的科学性和教育资源的共享性。 智慧环境建设则侧重于基于物联网的设备管理,通过智慧教室管理系统实现教室环境的智能控制和能效管理,打造绿色、节能的校园环境。电子班牌和校园信息发布系统的建设,将作为智慧校园的核心和入口,提供教务、一卡通、图书馆等系统的集成信息。 总体而言,智慧校园整体解决方案通过集成先进技术,不仅提升了校园的信息化水平,而且优化了教学和管理流程,为学生、教师和家长提供了更加便捷、个性化的教育体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值