本工具为网页自动化测试工具,不仅仅是用于商抢购测试,也可用于其它的填表作,傻瓜式可DIY自助编辑过程,仅供测试之用!请勿用于非法途径!否则后果自负!
全DIY理念设计款全能抢购神器出世了!拥有它,你想抢啥就抢啥
功能特点:
1.不绑定单一品种
2.支持傻瓜式添加目标按钮和输入框
3.支持多步骤(意思就是随便你几步,反正自己爱怎么DIY就怎么DIY)
4.支持目标按钮文本傻瓜式定位(如果不懂css选择器,用这个也可以)
5.CSS选择器+目标文本双重定位,再也不怕错过这个按钮了
这部分仅供python有基础的人看,源码方式打开
支持库安装指令(如果pip都不懂的话那就请自学一下python基础):
pip install pyqt5 -i https://pypi.tuna.tsinghua.edu.cn/simple/
pip install selenium -i https://pypi.tuna.tsinghua.edu.cn/simple/
然后将chromedriver.exe放入python环境中的Scripts文件夹中
更新日志:
20201221更新说明:
1.修复了暂停按钮文字错误的BUG
2.重写了脚本逻辑(现在是安装顺序一个一个判断的,就是必须前面的点成功了才能走到下一步,这样更加节省资源速度更快)
3.增加了输入密码,输入文字的功能(如果造成损失请自负!可以帮忙输入密码或者输入数量,但是请谨慎使用,万一你突然不想买了呢,哈哈)
4.增加定时启动功能(别忘记了要点全部开始,不然到时间也不会启动)
5.增加提前刷新的功能,这个和定时启动搭配使用(有些东西是先预约,到点预约,或者到点后降价等情况,就需要刷新/定时这样就可以匹配上了)
6.增加一件关闭所有浏览器的功能(这样就不需要每次搞错了又要重开软件了)
7.现在所有的修改都会被记录下来,重开软件时会加载你的设置情况
2021 01 04更新说明2.1:
新年来的第一次更新,给大家带来更加高端大气的版本,主要是吸收了一些网友的建议和反馈的不人性化的BUG,因此进行了以下改动
1.现在的目标按钮和CSS配置组合可以临时添加和删除了(以前是必须先设置然后再增加浏览器,这可以避免在出错的时候反复重开,浪费精力,当然我还是建议提前设置,更不容易出错!)
2.现在目标按钮文本支持##关键字,用来让浏览器自动拖动滚动条,将网页全部加载渲染(为了解决某些网页,加载不完整,需要的目标按钮没加载出来导致定位失败,比如京东的提交订单 注意%%,$$可以和##同时存在)
3.优化整体逻辑,杜绝bug
2021 02 21更新说明:
1.增加毫秒级的定时
2.加快判断速度,现在占用资源更多了,所以多开党要看情况要不要升级
3.新增一个时间校准工具.支持北京/京东/淘宝时间的校准(请配合毫秒级的定时来用,每个人电脑不一样不好计算误差,这样更加精准,误差更低!)
2021 03 26更新说明(可能是最后一次更新了,最近比较忙,并且怕有人加验证用来搞违法犯罪倒卖的事情):
1.增加自定义等待延时功能具体看下方的图,如果有时候还没缓冲完就点击成功了,可以在前面设置一个等待时间
2.微调速度(之前调的太过了),还有一些日志方面的改动
3.新增拖动配置功能(现在支持直接拖动.pkl文件进入列表框,一键完成配置的读取,方便读取网友的脚本配置懂的都懂)
4.支持最新89版本的google chrome
4.工具定位声明:浏览器自动化傻瓜式设计脚本,可用来随意控制多个浏览器,并非只能用来购物!
软件截图:
下面是部分源码打开的供大家参考!
main.py 这是入口
import threading,sys,os,pickle,time from codes.panicBuying import PanicBuying from PyQt5.QtWidgets import QApplication,QMainWindow,QInputDialog,QLineEdit,QMessageBox,QTableWidgetItem from PyQt5.QtCore import pyqtSignal,QObject,QDateTime from PyQt5.QtGui import QIcon from ui.main import Ui_MainWindow from selenium import webdriver from selenium.webdriver.chrome.options import Options class Myignals(QObject): #定义一种信号,然后确定参数的类型 log_add=pyqtSignal(str) def init_window_main(): global ui_main,window_main window_main.setWindowTitle('全能抢购神器-请自觉关闭杀毒软件以免造成意外卡死![url=http://www.52pojie.cn]www.52pojie.cn[/url]') window_main.setWindowIcon(QIcon('logo.ico')) #加载数据 load() # 自动调节宽度 ui_main.tab_mban.resizeColumnsToContents() #绑定按钮信号 ui_main.bt_openWeb.clicked.connect(openWeb) ui_main.bt_start.clicked.connect(true_or_Flase) window_main.closeEvent=close ui_main.bt_close_all.clicked.connect(reset) ui_main.tab_mban.cellChanged.connect(cellChanged) ui_main.bt_add.clicked.connect(add_line) ui_main.bt_sub.clicked.connect(sub_line) def reset(): global driver # 关闭所有的浏览器 for item in driver: item.quit() close_all=True start = False ui_main.bt_start.setText('2.全部开始') driver=[] log_add('重置成功!') def cellChanged(row, column): #自动调节宽度 ui_main.tab_mban.resizeColumnsToContents() def add_line(): count=len(ui_main.tab_mban.selectedItems()) if count > 0: #插入一行 row = ui_main.tab_mban.currentRow() print(row) ui_main.tab_mban.insertRow(row) else: ui_main.tab_mban.setRowCount(ui_main.tab_mban.rowCount() + 1) def sub_line(): if ui_main.tab_mban.rowCount() > 0: count = len(ui_main.tab_mban.selectedItems()) if count > 0: row = ui_main.tab_mban.currentRow() print(row) ui_main.tab_mban.removeRow(row) else: ui_main.tab_mban.setRowCount(ui_main.tab_mban.rowCount() - 1) def load(): ''' 读取配置项 :return: ''' try: with open(dataPath,'rb')as f: setting = pickle.load(f) sets=setting['items'] length = len(sets) print(setting) if length>0: #给这些控件初始化 ui_main.ed_url.setText(setting['url']) ui_main.dte_time.setDateTime(QDateTime.fromString(setting['dte_time'],'hh:mm:ss')) ui_main.cb_sfds.setChecked(setting['cb_sfds']) ui_main.cb_tqsx.setChecked(setting['cb_tqsx']) #清空 ui_main.tab_mban.clearContents() ui_main.tab_mban.setRowCount(length) ui_main.tab_mban.setColumnCount(3) print(sets) for i,im in enumerate(sets): store = QTableWidgetItem(im['store']) ui_main.tab_mban.setItem(i, 0, store) text=QTableWidgetItem(im['text']) ui_main.tab_mban.setItem(i, 1, text) css = QTableWidgetItem(im['css']) ui_main.tab_mban.setItem(i, 2, css) except Exception as err: print(err) def save(): ''' 保存配置项 :return: ''' items = [] # 将表格的内容存在items中 length = ui_main.tab_mban.rowCount() for i in range(length): try: items.append({'store': ui_main.tab_mban.item(i, 0).text(), 'text': ui_main.tab_mban.item(i, 1).text(), 'css': ui_main.tab_mban.item(i, 2).text()}) except: pass setting={'items':items, 'url':ui_main.ed_url.text(), 'dte_time':ui_main.dte_time.text(), 'cb_sfds':ui_main.cb_sfds.isChecked(), 'cb_tqsx':ui_main.cb_tqsx.isChecked()} with open(dataPath, 'wb')as f: pickle.dump(setting, f) print(setting) def close(enent): #关闭所有的浏览器 for item in driver: item.quit() #保存数据 save() def openWeb(): global driver,ms,close_all close_all = False #获取链接 url=ui_main.ed_url.text() #获取设置的时间 time_wait=ui_main.dte_time.text() #获取是否定时 wait=ui_main.cb_sfds.isChecked() # 获取是否提前刷新 refresh = ui_main.cb_tqsx.isChecked() # 将表格的内容存在items中 items=[] length=ui_main.tab_mban.rowCount() for i in range(length): items.append({'store':ui_main.tab_mban.item(i,0).text(),'text':ui_main.tab_mban.item(i,1).text(),'css':ui_main.tab_mban.item(i,2).text()}) # 创建浏览器 try: driver.append(webdriver.Chrome()) except: ui_main.ed_log.append('启动浏览器失败!请确定你的有安装谷歌浏览器和根目录有chromedriver.exe,并且版本大于等于87') ui_main.ed_log.append('浏览器下载:[url]https://www.google.cn/chrome/'[/url]) ui_main.ed_log.append('chromedriver.exe下载:[url]https://www.lanzoui.com/isdWeiim1ji'[/url]) driver=[] return # 创建线程 t.append(threading.Thread(target=hw.start, args=(str(len(driver)), driver[-1], ms, url, items, time_wait, wait, refresh))) # 设置主线程关闭时,它也跟着关闭 t[-1].setDaemon(True) # 开始运行 t[-1].start() ui_main.ed_log.append('现在请自己选择好产品的尺寸,规格,型号等参数,然后点全部开始,别关闭浏览器!') def true_or_Flase(): global start if len(driver)==0: log_add('请先增加浏览器') return if start==True: ui_main.bt_start.setText('2.全部开始') log_add('已经全部暂停!') start = False else: ui_main.bt_start.setText('2.全部暂停') log_add('已经全部开始!') start =True hw.start_kg =start def log_add(text): print(text) ui_main.ed_log.append(text) if __name__ == '__main__': dataPath='datas/set.pkl' # 自定义一个信号 ms = log_sg = Myignals() # 绑定日志更新的信号 ms.log_add.connect(log_add) #实例化抢购对象 hw = PanicBuying() t = []#线程容器 driver = []#浏览器容器 start=False#全局暂停和开始的开关 close_all=False app=QApplication(sys.argv) window_main = QMainWindow() # 主界面 ui_main = Ui_MainWindow() # 实例化 ui_main.setupUi(window_main) # 运行里面的代码 init_window_main() # 初始化和对接代码功能 with open('datas\main.qss', 'r')as f: style = f.read() window_main.setStyleSheet(style) window_main.show() sys.exit(app.exec_())
版权声明
版权说明: 仅限用于学习和研究目的;不得将上述内容用于商业和非法用途!否则一切后果自负。我们非常重视版权问题,如有侵权请邮件至(171373236#qq.com)与我们联系处理,敬请谅解!