这两天因为双十一来临,到处收集喵币,反反复复的点击操作搞得我十分头痛,遂产生了写个脚本自动点击的想法。
【低阶入门版本】之中不牵扯图像文字转换,或者图像匹配的问题,只是简单的屏幕开屏、点击和滑动。如果你对更智能化的程序有想法,欢迎回复与我一起研究,后续我会增添文字识别和定位,以适应在各类不同屏幕上进行此类操作。
在开始这篇文章前,首先你需要确认自己电脑上安装了 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刷淘宝喵币(低阶入门版),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新动态
- 小骆驼-《草原狼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]