本文目錄一覽:
- 1、python怎麼調用dll共享庫
- 2、如何用python調用應用程序的.dll文件
- 3、python裡面如何釋放DLL文件
- 4、有誰知道python怎麼調用c#的dll
- 5、python 調用 C++ 編譯的 dll
- 6、python 調用DLL的問題
python怎麼調用dll共享庫
可以的,python中一般有兩種方法調用DLL中的函數。1.直接使用函數名,函數名可以用dependencywalker等工具查看。(這個工具在vc或者vs的工具包中)[python]viewplaincopyimportctypesdll=CTYPES.CDLL(“test.dll”)res=test(3,4)2.使用Ordinal,Ordinal可以用dependencywalker等工具查看。[python]viewplaincopyimportctypesdll=CTYPES.CDLL(“test.dll”)res=dll[1](3,4)
如何用python調用應用程序的.dll文件
在python中調用dll文件中的介面比較簡單,實例代碼如下:
如我們有一個test.dll文件,內部定義如下:
extern “C”
{
int __stdcall test( void* p, int len)
{
return len;
}
python裡面如何釋放DLL文件
調用dll的代碼採用如下順序:
dll = CDLL(dllPath)
update_out = UpdateParamStruct()
dll.SeUpdaterGetParam(case.updateType, byref(update_out))
win32api.FreeLibrary(dll._handle)
這樣就可以在執行完後,dll文件不會處於佔用的狀態了~
有誰知道python怎麼調用c#的dll
1、首選運行工具 makepy.py。
2、這樣就可以查看 C# dll的 com導出的 py文件了。
Python編程makepy.py代碼如下:
# -*- coding: mbcs -*-
# Created by makepy.py version 0.5.00
# By python version 2.5.4 (r254:67916, Dec 23 2008, 15:10:54) [MSC v.1310 32 bit (Intel)]
# From type library ‘XGSharpLib.tlb’
“”””””
makepy_version = ‘0.5.00’
python_version = 0x20504f0
import win32com.client.CLSIDToClass, pythoncom, pywintypes
import win32com.client.util
from pywintypes import IID
from win32com.client import Dispatch
# The following 3 lines may need tweaking for the particular server
# Candidates are pythoncom.Missing, .Empty and .ArgNotFound
defaultNamedOptArg=pythoncom.Empty
defaultNamedNotOptArg=pythoncom.Empty
defaultUnnamedArg=pythoncom.Empty
CLSID = IID(‘{B38EF2FA-4639-40BC-B97C-7908CED04FF9}’)
MajorVersion = 1
MinorVersion = 0
LibraryFlags = 8
LCID = 0x0
from win32com.client import DispatchBaseClass
class IComXGSharpLib(DispatchBaseClass):
CLSID = IID(‘{D1965A94-0271-4C48-8AF6-2A56E256808B}’)
coclass_clsid = IID(‘{2302D874-18FE-4281-B329-9517F1BC8311}’)
def EncryptMd5(self, orignPwd=defaultNamedNotOptArg):
# Result is a Unicode object
return self._oleobj_.InvokeTypes(2, LCID, 1, (8, 0), ((8, 1),),orignPwd
)
def EncryptSHA1(self, orignPwd=defaultNamedNotOptArg):
# Result is a Unicode object
return self._oleobj_.InvokeTypes(1, LCID, 1, (8, 0), ((8, 1),),orignPwd
)
_prop_map_get_ = {
}
_prop_map_put_ = {
}
class _Object(DispatchBaseClass):
CLSID = IID(‘{65074F7F-63C0-304E-AF0A-D51741CB4A8D}’)
coclass_clsid = IID(‘{2302D874-18FE-4281-B329-9517F1BC8311}’)
def Equals(self, obj=defaultNamedNotOptArg):
return self._oleobj_.InvokeTypes(1610743809, LCID, 1, (11, 0), ((12, 1),),obj
)
def GetHashCode(self):
return self._oleobj_.InvokeTypes(1610743810, LCID, 1, (3, 0), (),)
# Result is of type _Type
def GetType(self):
ret = self._oleobj_.InvokeTypes(1610743811, LCID, 1, (13, 0), (),)
if ret is not None:
# See if this IUnknown is really an IDispatch
try:
ret = ret.QueryInterface(pythoncom.IID_IDispatch)
except pythoncom.error:
return ret
ret = Dispatch(ret, u’GetType’, ‘{BCA8B44D-AAD6-3A86-8AB7-03349F4F2DA2}’)
return ret
_prop_map_get_ = {
“ToString”: (0, 2, (8, 0), (), “ToString”, None),
}
_prop_map_put_ = {
}
# Default property for this class is ‘ToString’
def __call__(self):
return self._ApplyTypes_(*(0, 2, (8, 0), (), “ToString”, None))
def __unicode__(self, *args):
try:
return unicode(self.__call__(*args))
except pythoncom.com_error:
return repr(self)
def __str__(self, *args):
return str(self.__unicode__(*args))
def __int__(self, *args):
return int(self.__call__(*args))
from win32com.client import CoClassBaseClass
# This CoClass is known by the name ‘XGSharpLib.Security’
class Security(CoClassBaseClass): # A CoClass
CLSID = IID(‘{2302D874-18FE-4281-B329-9517F1BC8311}’)
coclass_sources = [
]
coclass_interfaces = [
IComXGSharpLib,
_Object,
]
default_interface = IComXGSharpLib
IComXGSharpLib_vtables_dispatch_ = 1
IComXGSharpLib_vtables_ = [
(( u’EncryptSHA1′ , u’orignPwd’ , u’pRetVal’ , ), 1, (1, (), [ (8, 1, None, None) ,
(16392, 10, None, None) , ], 1 , 1 , 4 , 0 , 28 , (3, 0, None, None) , 0 , )),
(( u’EncryptMd5′ , u’orignPwd’ , u’pRetVal’ , ), 2, (2, (), [ (8, 1, None, None) ,
(16392, 10, None, None) , ], 1 , 1 , 4 , 0 , 32 , (3, 0, None, None) , 0 , )),
]
_Object_vtables_dispatch_ = 1
_Object_vtables_ = [
(( u’ToString’ , u’pRetVal’ , ), 0, (0, (), [ (16392, 10, None, None) , ], 1 , 2 , 4 , 0 , 28 , (3, 0, None, None) , 0 , )),
(( u’Equals’ , u’obj’ , u’pRetVal’ , ), 1610743809, (1610743809, (), [ (12, 1, None, None) ,
(16395, 10, None, None) , ], 1 , 1 , 4 , 0 , 32 , (3, 0, None, None) , 0 , )),
(( u’GetHashCode’ , u’pRetVal’ , ), 1610743810, (1610743810, (), [ (16387, 10, None, None) , ], 1 , 1 , 4 , 0 , 36 , (3, 0, None, None) , 0 , )),
(( u’GetType’ , u’pRetVal’ , ), 1610743811, (1610743811, (), [ (16397, 10, None, “IID(‘{BCA8B44D-AAD6-3A86-8AB7-03349F4F2DA2}’)”) , ], 1 , 1 , 4 , 0 , 40 , (3, 0, None, None) , 0 , )),
]
RecordMap = {
}
CLSIDToClassMap = {
‘{D1965A94-0271-4C48-8AF6-2A56E256808B}’ : IComXGSharpLib,
‘{2302D874-18FE-4281-B329-9517F1BC8311}’ : Security,
‘{65074F7F-63C0-304E-AF0A-D51741CB4A8D}’ : _Object,
}
CLSIDToPackageMap = {}
win32com.client.CLSIDToClass.RegisterCLSIDsFromDict( CLSIDToClassMap )
VTablesToPackageMap = {}
VTablesToClassMap = {
‘{D1965A94-0271-4C48-8AF6-2A56E256808B}’ : ‘IComXGSharpLib’,
‘{65074F7F-63C0-304E-AF0A-D51741CB4A8D}’ : ‘_Object’,
}
NamesToIIDMap = {
‘_Object’ : ‘{65074F7F-63C0-304E-AF0A-D51741CB4A8D}’,
‘IComXGSharpLib’ : ‘{D1965A94-0271-4C48-8AF6-2A56E256808B}’,
}
3、舉例:Python調用C# dll中的 MD5加密方法。
python 調用 C++ 編譯的 dll
困難啊。通常調用C編寫的DLL就比較難。如果C++更難。如果說在linux還過得去。那麼在linux下還得去。在windows就更難了。標準不一樣。
建議你直接使用cython,輕鬆就搞定了。ctypes只是偶爾才用一下。
往往調用失敗與dll的封裝格式,編譯的方法,參數,版本都有關係。c++的函數命名方式也不同於C,似乎前面要加下劃線。
python 調用DLL的問題
那就是有內存泄露。內存沒有釋放。原因可能是多種。一種是你的DLL或者是AntiVC出了錯。另外一種是ctypes出錯。其中返回的內容沒有釋放內存。也許只有10個位元組,但是長期積累還是很可觀。
如果解決這個問題,就是穩定的程序,怎麼用都不會壞。
還有一個保守的辦法。如果你調用DLL的頻率不是特別快。比如每秒不超過2000次。那麼你可以將這個功能封裝在一個服務進程里。線程再通過介面去訪問。該 服務進程即使內存溢出崩潰了。也會自動重新啟動。這樣你的20個線程基本上只需要重試幾次,等服務進程重新啟動完成後,就可以獲得結果。基本不影響使用。操作系統也很安全。因為進程退出後,所有的遺留錯誤都會清空。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/196759.html