DLL
从内部使用文件的最简单方法是什么Python
?
具体来说,如何在不编写任何附加包装器C++
代码的情况下完成此功能Python
?
Python
与使用第三方库相比,本机功能是首选。
DLL
从内部使用文件的最简单方法是什么Python
?
具体来说,如何在不编写任何附加包装器C++
代码的情况下完成此功能Python
?
Python
与使用第三方库相比,本机功能是首选。
Answers:
为了易于使用,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.
# 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型的数据类型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
在我的情况),并调用函数与他们。
hllApiParams
做什么的?这些元组有什么意义?很难将本示例中的某些内容与文档进行匹配。
为了完整起见,在此处解释细节:
在Python中调用DLL函数非常容易。我有一个带有两个函数的自制DLL文件:
add
和sub
具有两个参数。
add(a, b)
返回两个数字的加法
sub(a, b)
返回两个数字的减法DLL文件的名称将为“ demo.dll”
程序:
from ctypes import*
# give location of dll
mydll = cdll.LoadLibrary("C:\\demo.dll")
result1= mydll.add(10,1)
result2= mydll.sub(10,1)
print "Addition value:"+result1
print "Substraction:"+result2
输出:
Addition value:11
Substraction:9
ctypes可用于访问dll,这是一个教程:
也许与Dispatch
:
from win32com.client import Dispatch
zk = Dispatch("zkemkeeper.ZKEM")
其中zkemkeeper是系统上已注册的DLL文件...之后,您可以通过调用函数来访问它们:
zk.Connect_Net(IP_address, port)
我提出关于如何建立一个完全样例shared library
,并用它在Python
借助于ctypes
。我考虑Windows
并处理DLLs
。需要两个步骤:
在shared library
我考虑的是以下内容,包含在在testDLL.cpp
文件中。唯一的功能testDLL
只是接收int
并打印它。
#include <stdio.h>
extern "C" {
__declspec(dllexport)
void testDLL(const int i) {
printf("%d\n", i);
}
} // extern "C"
要从命令行运行一个DLL
withVisual Studio
"C:\Program Files (x86)\Microsoft Visual Studio 12.0\Common7\Tools\vsdevcmd"
设置包含路径,然后运行
cl.exe /D_USRDLL /D_WINDLL testDLL.cpp /MT /link /DLL /OUT:testDLL.dll
生成DLL。
DLL
从IDE 构建或者,DLL
可以使用Visual Studio
以下方式构建:
在Python下,执行以下操作
import os
import sys
from ctypes import *
lib = cdll.LoadLibrary('testDLL.dll')
lib.testDLL(3)
ctypes将是最容易使用的东西,但是使用不当会使Python崩溃。如果您想快速地做某事,并且小心一点,那就太好了。
我鼓励您查看Boost Python。是的,它要求您编写一些C ++代码并具有C ++编译器,但实际上您无需学习C ++即可使用它,并且可以从Microsoft获得免费的(如啤酒中的)C ++编译器。
如果DLL是COM库类型,则可以使用pythonnet。
pip install pythonnet
然后在您的python代码中,尝试以下操作
import clr
clr.AddReference('path_to_your_dll')
然后根据DLL中的类实例化一个对象,并访问其中的方法。