这两天因为双十一来临,到处收集喵币,反反复复的点击操作搞得我十分头痛,遂产生了写个脚本自动点击的想法。
【低阶入门版本】之中不牵扯图像文字转换,或者图像匹配的问题,只是简单的屏幕开屏、点击和滑动。如果你对更智能化的程序有想法,欢迎回复与我一起研究,后续我会增添文字识别和定位,以适应在各类不同屏幕上进行此类操作。
在开始这篇文章前,首先你需要确认自己电脑上安装了 Python 或者 Anacoda(Python的一个集成类库),除此之外安装了ADB(如果没有安装请查看这篇博文),确认用USB链接到了手机,手机需开启USB调试。
如果上述工作全部完成,那我们在接下的过程中应该会进行的很愉快。
首先新建一个Python文件(.py的),引入一些可能会用到的库。
# coding: utf-8 import os import sys import subprocess import time import math from PIL import Image import random
在这之后,我们写上一些按钮、点击与滑动的函数。
def click(x, y): # 点击屏幕(x, y)坐标点 cmd = 'adb shell input tap {x1} {y1}'.format(x1=x, y1=y) os.system(cmd) def slide(x, y, ex, ey): # 滑动屏幕从(x, y)坐标点到(ex, ey)坐标点 print("滑动屏幕") cmd = 'adb shell input swipe {x1} {y1} {x2} {y2}'.format(x1=x, y1=y, x2=ex, y2=ey) os.system(cmd) def touch(key): # 按动相应的按键 if key == "back": print("> 返回按键") os.system('adb shell input keyevent 4') elif key == "light": print("> 开屏按键") os.system('adb shell input keyevent 26') time.sleep(1) # 等待1s 等手机反应
写一个截屏并且保存的函数,以便我们之后进阶的时候会用到(入门版可跳过)。
在此处这个 screenshot_way 代表截屏的方式,根据手机型号的不同,截屏方式会有差别,如果你的手机不适用与此截屏方式,可在此函数中继续增加其它的截屏方式。
screenshot_way = 2 def pull_screenshot(filename): ''' 获取截屏 ''' global screenshot_way if screenshot_way == 2 or screenshot_way == 1: process = subprocess.Popen('adb shell screencap -p', shell=True, stdout=subprocess.PIPE) screenshot = process.stdout.read() if screenshot_way == 2: binary_screenshot = screenshot.replace(b'\r\n', b'\n') else: binary_screenshot = screenshot.replace(b'\r\r\n', b'\n') f = open(filename, 'wb') f.write(binary_screenshot) f.close() elif screenshot_way == 0: os.system('adb shell screencap -p /sdcard/'+filename) os.system('adb pull /sdcard/'+filename+' .')
因为我觉得手机可能会息屏,所以写个函数判断一下是不是黑屏(入门版可跳过)。
在屏幕上平均取了100个点(长取10份,宽取10份),判断如果都为黑色,则为息屏状态。
def is_black(im): im_pixel = im.load() piece_x_dilation = int(im.size[1]/10) piece_y_dilation = int(im.size[1]/10) piece_x_max = im.size[0] piece_y_max = im.size[1] for i in range(0, piece_x_max, piece_x_dilation): for j in range(0, piece_y_max, piece_y_dilation): if not im_pixel[i, j][0] == 0 or not im_pixel[i, j][1] == 0 or not im_pixel[i, j][2] == 0 or not im_pixel[i, j][3] == 255: return False print("熄屏状态...") return True
最后,准备工作就全部完成了,主函数如下。
def main(): ''' 主函数 ''' while True: pull_screenshot('autojump.png') # 截图并保存为autojump.png im = Image.open('./autojump.png') # 打开截图autojump.png if is_black(im): # 如果没写这个函数可以去掉if...一直到else touch('light') # 点亮屏幕 slide(int(im.size[0]/2), int(im.size[1]/1.1), int(im.size[0]/2), int(im.size[1]/2)) # 因为我的手机是上滑解锁,所以上滑了一下 else: print("点击进入浏览") click(591, 783) # 这个位置是进入“领喵币”界面底下,那个“去逛逛”按钮的位置 # 因为是 入门版 ,所以这个坐标就写死了,是我用PS量的(手动滑稽) for i in range(0, 10): # 点开之后随机向下滑动几下 # 滑动位置也有着微小的随机变化(怕被检测出来是机器) if random.random() > 0.5: slide(int(im.size[0]/2 - (random.random()*20) + 10), int(im.size[1]/1.1 - (random.random()*20) + 10), int(im.size[0]/2 - (random.random()*20) + 10), int(im.size[1]/1.1 - (random.random()*20) - 300)) # 向上稍微滑滑 time.sleep(3) # 等待3s touch('back') # 返回按键 time.sleep(1) # 等待1s
总结
以上所述是小编给大家介绍的使用Python刷淘宝喵币(低阶入门版),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]