为了易于使用,ctypes是必经之路。
以下ctypes示例来自我编写的实际代码(在Python 2.5中)。到目前为止,这是我找到的最简单的方法来完成你的要求。
import ctypes# Load DLL into memory.hllDll = ctypes.WinDLL ("c:\PComm\ehlapi32.dll")# Set up prototype and parameters for the desired function call.# HLLAPIhllApiProto = ctypes.WINFUNCTYPE ( ctypes.c_int, # Return type. ctypes.c_void_p, # Parameters 1 ... ctypes.c_void_p, ctypes.c_void_p, ctypes.c_void_p) # ... thru 4.hllApiParams = (1, "p1", 0), (1, "p2", 0), (1, "p3",0), (1, "p4",0),# Actually map the call ("HLLAPI(...)") to a Python name.hllApi = hllApiProto (("HLLAPI", hllDll), hllApiParams)# This is how you can actually call the DLL function.# Set up the variables and call the Python name with them.p1 = ctypes.c_int (1)p2 = ctypes.c_char_p (sessionVar)p3 = ctypes.c_int (1)p4 = ctypes.c_int (0)hllApi (ctypes.byref (p1), p2, ctypes.byref (p3), ctypes.byref (p4))
的ctypes东西具有:(所有的C型的数据类型int,char,short,void*,等等),并且可以通过数值或引用传递。尽管我的示例没有这样做,但它也可以返回特定的数据类型(HLL API通过修改引用传递的变量来返回值)。
就上面显示的特定示例而言,IBM的EHLLAPI是一个相当一致的接口。
所有呼叫传递四个空指针(EHLLAPI将通过第四个参数的指针返回代码回来,一个int是这样,而我指定int的返回类型,我可以放心地忽略它),按照IBM的文档在这里。换句话说,该函数的C变体为:
int hllApi (void *p1, void *p2, void *p3, void *p4)
这使得一个简单的
ctypes函数可以执行EHLLAPI库提供的任何功能,但是其他库可能需要为
ctypes每个库函数设置一个单独的函数。
从的返回值
WINFUNCTYPE是一个函数原型,但是你仍然必须设置更多的参数信息(类型之外)。每个元组中
hllApiParams都有一个参数“方向”(1 =输入,2 =输出,依此类推),一个参数名称和一个默认值-
ctypes有关详细信息,请参见doco
一旦有了原型和参数信息,就可以创建一个Python“可调用” hllApi函数来调用该函数。你只需创建(所需的变量
p1通过
p4在我的情况),并调用函数与他们。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)