为了便于使用, ctypes是要走的路。
下面的ctypes例子来自我写的实际代码(在Python 2.5中)。 到目前为止,这是我find的最简单的方法。
import ctypes # Load DLL into memory. hllDll = ctypes.WinDLL ("c:\\PComm\\ehlapi32.dll") # Set up prototype and parameters for the desired function call. # HLLAPI hllApiProto = 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型数据types( int , char , short , void*等等),可以通过值或引用传递。 它也可以返回特定的数据types,虽然我的例子没有这样做(HLL API通过修改引用传递的variables来返回值)。
根据上面显示的具体示例,IBM的EHLLAPI是一个相当一致的接口。
所有调用都传递了四个void指针(EHLLAPI通过第四个参数返回返回码,一个指向int的指针,而我指定int作为返回types,我可以放心地忽略它)。 换句话说,函数的C变体将是:
int hllApi (void *p1, void *p2, void *p3, void *p4)
这使得一个简单的ctypes函数能够完成EHLLAPI库提供的任何操作,但其他库可能需要为每个库函数设置单独的ctypes函数。
WINFUNCTYPE的返回值是一个函数原型,但是您仍然需要设置更多的参数信息(超过和超过这些types)。 hllApiParams中的每个元组都有一个参数“direction”(1 = input,2 = output等等),一个参数名和一个默认值 – 详见ctypes doco
一旦你有原型和参数信息,你可以创build一个Python“可调用” hllApi来调用该函数。 你只需创build所需的variables(在我的情况下, p1到p4 ),并与他们调用函数。