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