首先是python的一个简单函数
class Hello:
def __init__(self, x):
self.a = x
def print(self, x=None):
print(x)
def xprint():
print("hello world")
if __name__ == "__main__":
xprint()
h = Hello(5)
h.print()1
下面是C语言
#include <python3.4m/Python.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
Py_Initialize()
// 将当前目录加入sys.path
PyRun_SimpleString("import sys")
PyRun_SimpleString("sys.path.append('./')")
// 导入hello.py模块
PyObject *pmodule = PyImport_ImportModule("hello")
// 获得函数xprint对象,并调用,输出“hello world\n”
PyObject *pfunc = PyObject_GetAttrString(pmodule, "xprint")
PyObject_CallFunction(pfunc, NULL)
// 获得类Hello并生成实例pinstance,并调用print成员函数,输出“5 6\n”
PyObject *pclass= PyObject_GetAttrString(pmodule, "Hello")
PyObject *arg = Py_BuildValue("(i)", 5)
PyObject *pinstance = PyObject_Call(pclass, arg, NULL)
PyObject_CallMethod(pinstance, "print", "i", 6)
Py_Finalize()
return 0
}
编译命令如下:
gcc pyapi.c -lpython3.4m -o pyapi
python.h是基于python-devel的开发包,比如你要用到c调用python去执行一些任务,这个时候python.h就是你的好帮手。在我所理解一般用它都有两个场景:1. 借助语言优势解决问题;
2. 简化开发难度,偷懒;
在我这,我用它的主要目的在于加入扫描框架的依赖,毕竟lua的学习成本挺高的,如果正好这个安全人员不懂lua,只懂python咋整?能不成让他学习lua么?成本是一个方面,更多的是怎么快起来。一个团队,在快节奏下才能成长起来。
正好手上有一台机器,别人给我用来测试玩的,我就拿来做些调试和环境的测试。还没到生产环境,就遇到不少的坑,当时在线上环境也有测试,陪着运维的小哥一起搞,不断的测试和调整,折腾到很晚才搞成功,这里记录下过程。
默认的情况下,python.h应该在这个位置,但是测试的结果说找不到。内心是崩溃的,我在mac下是正常的。
用find命令找当前系统中的python.h的版本,发现只有2.6的,但是我按照了python2.7,这个版本完全错乱了。
心想,坑啊~~ 为了解决问题,少不得需要重新编译之类的屁事,当然,我们也干了这事,最后发现仍然不行,参考的例子(知乎上的指引,坑b)如下:
首先,你需要先把所有的python环境卸载,然后安装同步的环境,比如python2.7.12,devel也是python2.7.12,还有就是libs也必须是,不然弄不了,另外,编译安装默认不靠谱,最好就是rpm的方式来。包我留下,有需要的玩。
这是我的解决方案,当前完美解决我的问题,另外,推荐大家按照这个方式来搞,特别在centos环境下,这个比较坑爹。
可以使用Python的ctypes模块来实现C和Python之间的通信,从而实现C调用Python训练模型的输入。ctypes模块提供了一种调用共享库的方法,可以将Python的变量和函数转换为C语言的变量和函数,从而实现C调用Python的功能。
要实现C调用Python训练模型的输入,需要做的第一步是在C程序中定义一个Python函数,并将其转换为C函数。然后,可以使用ctypes模块将Python函数转换为C函数,从而实现C调用Python训练模型的输入。