Python中调用Win32API 通常都是使用 PyWin32或者ctypes。但要么依赖文件较多,要么用法繁琐。
这里介绍在Python中调用Win32 API 或者COM组件的另一个更好的,功能也更强大的解决方案。
首先需要确保安装的是 32位的Python(2.x 或者 3.x 均可)。
下载通用库:win32exts for Python:
https://github.com/tankaishuai/win32exts_for_Python
将win32exts.pyd 放入 Python/DLLs 目录下即可。发布时 仅有此一个文件而已。
import win32exts
win32exts调用的基本用法如下:
(1)常规具名函数(以MessageBoxA/W为例)调用:
首先需要导入模块符号。第一个参数为待加载的模块名,可以带路径,传入"*"表示当前进程的所有模块;
第二个参数表示函数符号名称,传入"*"表示该模块的所有符号。
win32exts.load_sym("*", "*") 或 win32exts.load_sym("C:\\windows\\system32\\user32.dll", "MessageBoxW") 或 win32exts.load_sym("user32", "MessageBoxA") 或 win32exts.load_sym("user32", "*")
然后:
win32exts.MessageBoxA(0, "call MessageBoxA", "", 1)
宽字符需要用 win32exts.L() 包装,与C/C++雷同。
win32exts.MessageBoxW(0, win32exts.L("call MessageBoxW"), None, 1)
(2)带回调的函数(以EnumWindows为例)调用:
先分配一块内存后面用:
g_buf = win32exts.malloc(2*260)
定义一个回调函数:
def EnumWndProc(args): #【args为参数包,以下取参数】 hWnd = win32exts.arg(args, 1) lParam = win32exts.arg(args, 2) win32exts.GetWindowTextW(hWnd, g_buf, 260) #【读取内存中的宽字符串】 #【read_***系列接口读内存,write_***系列接口写内存】 strText = win32exts.read_wstring(g_buf, 0, -1) win32exts.MessageBoxW(0, win32exts.L(strText), g_buf, 1) strRetVal = "1, 8" g_index = g_index + 1 if g_index > 3: #【假设只弹框三次】 strRetVal = "0, 8" #【返回值是形如这样的字符串: "回调返回值, 参数字节数", # 对于 cdecl 调用约定,参数字节数总是取 0 】 return strRetVal
然后调用:
win32exts.EnumWindows(win32exts.callback("EnumWndProc"), 0) win32exts.callback()用于包装一个Python回调函数。
(3)匿名(非具名)函数调用:
假设通过某个接口获取了某函数的地址 lFuncAddr,然后可以类似下述方式调用:
win32exts.push_value(arg1) 【参数是整数】 win32exts.push_wstring("arg2") 【参数是宽字符串】 win32exts.push_astring(arg3) 【参数是多字节字符串】 win32exts.push_double(arg4) 【参数是双精度浮点数】 win32exts.push_float(arg5) 【参数是单精度浮点数】 win32exts.push_function("FunctionName") 【参数是回调函数】 iRetVal = win32exts.call( lFuncAddr )
当然具名函数也可以类似调用,例如:
win32exts.push_value(0) win32exts.push_astring("Py_MessageBoxA_V1") win32exts.push_value(0) win32exts.push_value(0) iRetVal = win32exts.sym_call("MessageBoxA") #【或用 func_call】
(4)调用COM组件:
import win32exts # # 测试 COM 组件, 打开计算器 # wsh = win32exts.co_create_ ("W .Shell") win32exts.co_push_start() win32exts.push_bstr("calc") win32exts.co_invoke(wsh, "Run") win32exts.co_release(wsh)
知识点扩展:
python调用windows api
import ctypes # 方式一 ctypes.windll.user32.MessageBoxA(None, 'message', 'title', 0) # 方式二 ctypes.WinDLL('user32.dll').MessageBoxA(None, 'message', 'title', 0)
总结
以上所述是小编给大家介绍的Python 调用 Windows API COM 新法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。