python實(shí)現(xiàn)自動(dòng)搶課腳本的示例代碼
自動(dòng)搶課腳本使用手冊(cè)
@danteking dating from 2021.12.7 and last updating at 2021.12.8
gitee倉(cāng)庫(kù)
github倉(cāng)庫(kù)
借助pyautogui庫(kù),我們可以輕松地控制鼠標(biāo)、鍵盤(pán)以及進(jìn)行圖像識(shí)別,實(shí)現(xiàn)自動(dòng)搶課的功能
1.準(zhǔn)備工作
我們?cè)趥}(cāng)庫(kù)里提供了2個(gè)必須的文件,包括:
- auto_get_lesson_pic_recognize.py:腳本文件
- info.xlsx:執(zhí)行操作信息文件
在運(yùn)行這個(gè)腳本(auto_get_lesson_pic_recognize.py)前,你需要:
1.安裝python并成功配置環(huán)境變量,可以在cmd下這樣檢查;若返回版本號(hào),則已安裝
python --version
2.安裝以下的依賴(lài),windows用戶(hù)請(qǐng)以管理員用戶(hù)運(yùn)行cmd并依次執(zhí)行:
# pyautogui庫(kù) pip install pyautogui # 讀取excel表格的庫(kù) pip install xlrd==1.2.0 # 向計(jì)算機(jī)的剪貼板發(fā)送文本/從計(jì)算機(jī)剪貼板接收文本的庫(kù) pip install pyperclip # 計(jì)算機(jī)視覺(jué)庫(kù) pip install opencv-python # 圖像處理庫(kù) pip install pillow
到此,成功安裝了5個(gè)庫(kù)
2.配合使用py腳本和xlsx文件
第一步
需要將搶課的每一步所需要點(diǎn)擊的圖標(biāo)/超鏈接在頭腦中想清楚
第二步
將搶課每一步的所需點(diǎn)擊的圖標(biāo)/超鏈接截圖,保存在和py腳本同一路徑下
打開(kāi)excel表格,根據(jù)第一行提示在單元格中進(jìn)行輸入:
A列------備注(可填可不填)
B列------操作類(lèi)型,目前包括:
- 1.左鍵單擊(循環(huán)直到找到圖片為止):意思就是如果沒(méi)有找到你設(shè)置的那張圖片,它就一直找下去,找不到就不停;你所設(shè)置的次數(shù)是找到成功的次數(shù)
- 2.輸入字符串
- 3.等待
- 4.熱鍵
- 5.左鍵單擊(無(wú)需找到圖片):找圖片不管找沒(méi)找到,就找那這么多次,次數(shù)=找到成功的次數(shù)+找到失敗的次數(shù)
C列------B列的參數(shù)
- 待點(diǎn)擊圖標(biāo)名(包括圖片后綴名,如.png)
- 等待的時(shí)間(秒)
- 輸入的字符串
- 熱鍵
D列------單擊重復(fù)次數(shù)
- 不填,默認(rèn)為1
- 若想無(wú)限單擊,填-1
按照你的選課步驟從第2行開(kāi)始順序填寫(xiě)excel表格的執(zhí)行步驟
此時(shí),保存excel表格
第三步
我們打開(kāi)需要進(jìn)行操作的選課網(wǎng)頁(yè)
我們?cè)赾md下切換到腳本所在目錄
# 切換到D盤(pán) D: # 切換到xx文件夾 cd xx python auto_get_lesson_pic_recognize.py
根據(jù)提示執(zhí)行即可
上圖示例
3.auto_get_lesson_pic_recognize功能介紹
(1).搶課一次
注意
截圖時(shí)請(qǐng)隨機(jī)應(yīng)變,匹配到圖像后,鼠標(biāo)自動(dòng)點(diǎn)擊圖像正中央,建議配合qq截圖,ctrl+a/t+a,選取一個(gè)獨(dú)一無(wú)二的標(biāo)記在截圖中并且將所要點(diǎn)擊的點(diǎn)放在qq截圖四個(gè)藍(lán)點(diǎn)的中央
- 如果遇到同一畫(huà)面中需要點(diǎn)擊的圖標(biāo)存在多個(gè)一樣的,沒(méi)有特征參照物,可以在那一步設(shè)置等待若干秒,手動(dòng)點(diǎn)擊圖標(biāo)
- 若未成功識(shí)別圖片,將循環(huán)執(zhí)行識(shí)別操作;手動(dòng)點(diǎn)擊圖標(biāo)成功,excel表格中中的指令也會(huì)跳到下一條
- 考慮到網(wǎng)絡(luò)延遲問(wèn)題,建議合理利用等待功能
(2).蹲點(diǎn)撿漏
在搶課一次的基礎(chǔ)上套了一層死循環(huán)
巧妙利用f5、左鍵單擊(循環(huán)直到找到圖片為止)、左鍵單擊(無(wú)需找到圖片),可以24h掛機(jī)實(shí)現(xiàn)蹲點(diǎn)撿漏
請(qǐng)發(fā)揮你的聰明才智,正確截圖
4.坐標(biāo)版本(不建議使用)
坐標(biāo)版本位于coordinate_version目錄下
如果能夠確切知道所點(diǎn)擊的位置的坐標(biāo),可以選用坐標(biāo)版本
配合qq截圖,你能夠輕松知道你的鼠標(biāo)在1920×1080分辨率下在屏幕上的坐標(biāo)(以像素為單位)
順序排列單擊位置的坐標(biāo),實(shí)現(xiàn)搶課
excel表格中根據(jù)提示填寫(xiě)坐標(biāo)、操作
5.代碼
import pyautogui import time import xlrd import pyperclip # 定義鼠標(biāo)事件 # duration類(lèi)似于移動(dòng)時(shí)間或移動(dòng)速度,省略后則是瞬間移動(dòng)到指定的位置 def Mouse(click_times, img_name, retry_times): if retry_times == 1: location = pyautogui.locateCenterOnScreen(img_name, confidence=0.9) if location is not None: pyautogui.click(location.x, location.y, clicks=click_times, duration=0.2, interval=0.2) elif retry_times == -1: while True: location = pyautogui.locateCenterOnScreen(img_name,confidence=0.9) if location is not None: pyautogui.click(location.x, location.y, clicks=click_times, duration=0.2, interval=0.2) elif retry_times > 1: i = 1 while i < retry_times + 1: location = pyautogui.locateCenterOnScreen(img_name,confidence=0.9) if location is not None: pyautogui.click(location.x, location.y, clicks=click_times, duration=0.2, interval=0.2) print("重復(fù){}第{}次".format(img_name, i)) i = i + 1 # cell_value 1.0:左鍵單擊 # 2.0:輸入字符串 # 3.0:等待 # 4.0:熱鍵 # 任務(wù)一:進(jìn)行一輪搶課 def WorkFunction1(sheet): i = 1 while i < sheet.nrows: # 取excel表格中第i行操作 cmd_type = sheet.cell_value(i, 1) # 1:左鍵單擊 if cmd_type == 1.0: # 獲取圖片名稱(chēng) img_name = sheet.cell_value(i, 2) retry_times = 1 if sheet.cell_type(i, 3) == 2 and sheet.cell_value(i, 3) != 0: retry_times = sheet.cell_value(i, 3) Mouse(1, img_name, retry_times) print("單擊左鍵:{} Done".format(img_name)) # 2:輸入字符串 elif cmd_type == 2.0: string = sheet.cell_value(i, 2) pyperclip.copy(string) pyautogui.hotkey('ctrl','v') print("輸入字符串:{} Done".format(string)) # 3:等待 elif cmd_type == 3.0: wait_time = sheet.cell_value(i, 2) time.sleep(wait_time) print("等待 {} 秒 Done".format(wait_time)) # 4:鍵盤(pán)熱鍵 elif cmd_type == 4.0: hotkey = sheet.cell_value(i, 2) # 防止刷新過(guò)快停留在原網(wǎng)頁(yè) time.sleep(1) pyautogui.hotkey(hotkey) print("按下 {} Done".format(hotkey)) time.sleep(1) i = i + 1 # 任務(wù)二:蹲點(diǎn)等人退課 def WorkFunction2(sheet) : while True: WorkFunction1(sheet) time.sleep(2) if __name__ == '__main__': start_time = time.time() file = "info.xlsx" # 打開(kāi)文件 xr = xlrd.open_workbook(filename=file) # 通過(guò)索引順序獲取表單 sheet = xr.sheet_by_index(0) print("------歡迎使用自動(dòng)搶課腳本------") print("---------@danteking---------") print("1.搶課一次") print("2.蹲點(diǎn)等人退課后搶指定課") choice = input(">>") start_time = time.time() if choice == "1": WorkFunction1(sheet) elif choice == "2": WorkFunction2(sheet) else: print("非法輸入,退出") end_time = time.time() time_consume = end_time - start_time time_consume = ('%.2f' % time_consume) print("耗時(shí) {} 秒".format(time_consume))
到此這篇關(guān)于python實(shí)現(xiàn)自動(dòng)搶課腳本的示例代碼的文章就介紹到這了,更多相關(guān)python 自動(dòng)搶課腳本內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決python3 json數(shù)據(jù)包含中文的讀寫(xiě)問(wèn)題
今天小編就為大家分享一篇解決python3 json數(shù)據(jù)包含中文的讀寫(xiě)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-05-05python網(wǎng)絡(luò)編程學(xué)習(xí)筆記(五):socket的一些補(bǔ)充
前面已經(jīng)為大家介紹了python socket的一些相關(guān)知識(shí),這里為大家補(bǔ)充下,方便需要的朋友2014-06-06django利用request id便于定位及給日志加上request_id
這篇文章主要介紹了django利用request id便于定位及給日志加上request_id的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用django具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧2018-08-08python雙端隊(duì)列原理、實(shí)現(xiàn)與使用方法分析
這篇文章主要介紹了python雙端隊(duì)列原理、實(shí)現(xiàn)與使用方法,結(jié)合實(shí)例形式分析了Python雙端隊(duì)列的概念、原理、定義及使用方法,需要的朋友可以參考下2019-11-11Python簡(jiǎn)單實(shí)現(xiàn)詞云圖代碼及步驟解析
這篇文章主要介紹了Python簡(jiǎn)單實(shí)現(xiàn)詞云圖代碼解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06Python利用pyodbc庫(kù)將文件信息插入Access數(shù)據(jù)庫(kù)
在日常編程工作中,我們經(jīng)常需要處理文件和文件夾,所以本文將介紹如何使用Python編程語(yǔ)言和wxPython庫(kù)創(chuàng)建一個(gè)簡(jiǎn)單的文件瀏覽器界面,使用戶(hù)能夠選擇文件夾并將文件信息插入到Access數(shù)據(jù)庫(kù)中,需要的可以參考下2023-08-08