3 回答

TA贡献1830条经验 获得超9个赞
您应该显示.argtypes和.restype尝试,但是尝试一下:
from ctypes import wintypes as w
class FTRSCAN_IMAGE_SIZE(ctypes.Structure):
_fields_ = [('nWidth', ctypes.c_int),
('nHeight', ctypes.c_int),
('nImageSize', ctypes.c_int)]
FTRHANDLE = ctypes.c_void_p
lib = ctypes.WinDLL('ftrScanAPI.dll')
lib.ftrScanOpenDevice.argtypes = None
lib.ftrScanOpenDevice.restype = FTRHANDLE
lib.ftrScanGetImageSize.argtypes = FTRHANDLE,ctypes.POINTER(FTRSCAN_IMAGE_SIZE)
lib.ftrScanGetImageSize.restype = w.BOOL
检查WinDLLvs. 的使用CDLL。您的Python是否为64位并不重要,但是在32位Python上却有所不同。使用CDLL如果函数使用C调用约定(__cdecl)和WinDLL若函数使用__stdcall调用约定。如果头文件不清楚,则默认通常为__cdecl。 编辑:从API链接中的另一个答案,它是__stdcall并且WinDLL应该使用。

TA贡献1818条经验 获得超3个赞
问题似乎只是设备句柄是一个64位实体(一个类型定义的指向void的指针)。它可以在Windows 7中正常工作只是偶然,因为句柄的高33位正确为零。
ctypes中所有函数的返回类型默认为32位int。现在,在Windows 10中,似乎已经设置了第32位(符号位),当将handle-coerced-to-int推入64位堆栈进行函数调用时,这会导致符号扩展。结果地址的所有高位都设置为(0xFFFFFFFFA ...),它指向内核空间而不是用户空间。
因此,也许您可以使用
lib.ftrScanOpenDevice.restype = c_void_p
这并不是说您不应该为所有函数定义参数和返回类型-您应该这样做,否则它们将仅遵循C语言的默认参数提升规则,并且可以工作...或者完全无法工作,具体取决于函数原型本身是否与默认参数提升兼容。例如,如果不定义原型,则不能正确调用任何接受floats作为参数的函数。
添加回答
举报