最近微信“拍一拍”火遍了各大微信群,并迅速占据了热搜话题榜
于是我突发奇想,决定用pyhton自动实现微信“拍一拍”,没想到还真给搞成功了,整个过程才用了30行代码,下面给大家介绍一下具体实现步骤:
本文亮点:
用appium模拟操控手机并截图,通过图像识别定位好友头像坐标,最后用appium模拟双击头像坐标,以此实现“拍一拍”功能。
具体步骤:
一、用appium操控手机
关于appium的安装及使用方法,之前已经写过很多了,这里就不再赘述了,直接进入操作步骤
用python打开微信,代码如下:
- desired_caps = {"platformName": "Android",
- "deviceName": "VOG-AL00",
- "appPackage": "com.tencent.mm",
- "appActivity": ".ui.LauncherUI",
- "noReset": "true",
- "fullReset": "false"}
- server = 'http://localhost:4723/wd/hub'
- driver = webdriver.Remote(server, desired_caps)
难点在于desired_cap参数的配置,这里再给大家介绍一下:
- platformName:表示设备操作系统
- deviceName:表示设备名称
- apppackage:表示app程序包名
- appActivity:表示app入口Activity名。
将手机连接电脑,打开开发者模式,运行此程序,就会发现手机自动打开了微信。
二、模拟双击头像
原理介绍
我们都知道,微信“拍一拍”是通过双击好友头像实现的,如下图所示:
想要双击头像,就要先获得头像在屏幕中的坐标
这里给大家介绍1个函数:
基于Python-opencv2的目标定位模块:Aircv使用其find_template函数,可以查找目标图像在原始图像中的坐标范围,用法如下:
- def matchImg(imgsrc, imgobj, confidencevalue=0.7):
- imsrc = ac.imread(imgsrc)
- imgobj = ac.imread(imgobj)
- match_result = ac.find_template(imsrc, imgobj,confidencevalue)
- return match_result
其中imgsrc=原始图片路径,imgobj=待查找的目标图片路径。
如果未找到,则match_result=None;
若找到,则返回如下数据:
- {'result':(570.0, 2771.0), 'rectangle': ((30, 1601), (30, 3941), (1110, 1601), (1110,3941)), 'confidence': 0.999999463558197}
其中:
- result为匹配图片在原始图片上的中心坐标点,也就是我们要找的点击点;
- rectangle为匹配图片在原始图像上四边形的坐标;
- confidence为匹配相似率。
那么该如何在程序中自动获取获取好友头像坐标呢?
在客户端appium中,可以确定头像在屏幕中的像素为140×140我们可以先把好友头像保存,再用ps把头像改为此像素。
然后在程序中创建1个while循环,在第一步完成的基础上,手动进入好友聊天框(其实也可以通过识别好友头像自动进入)
通过appium对手机屏幕截图并命名为src.png,将其和头像路径(obj.png)导入1中的检测函数:
- driver.save_screenshot('src.png')
- imgsrc='src.png'
- imgobj='obj.png'
- match_result=matchImg(imgsrc, imgobj)
若返回None,则说明聊天窗口没检测到好友头像,继续循环;
若检测到头像坐标,则解析返回的坐标数据,用for循环模拟双击坐标位置:
- if match_result is not None:
- result = [match_result['rectangle'][0], match_result['rectangle'][3]]
- for i in range(2):
- driver.tap(result,100)
- print('拍成功')
- else:
- print('没找到头像')
这样就大功告成了
是不是很简单?
小结:本文介绍了用python模拟微信“拍一拍”的主要思路,感兴趣的可以接着做下去,实现一些有趣的功能,例如,监控微信群聊,谁发消息就“拍”谁一下,或者把群聊用户挨个拍一遍,都挺有意思的。