python實(shí)現(xiàn)自動(dòng)搶課腳本的示例代碼
自動(dòng)搶課腳本使用手冊(cè)
@danteking dating from 2021.12.7 and last updating at 2021.12.8
gitee倉庫
github倉庫
借助pyautogui庫,我們可以輕松地控制鼠標(biāo)、鍵盤以及進(jìn)行圖像識(shí)別,實(shí)現(xiàn)自動(dòng)搶課的功能
1.準(zhǔn)備工作
我們?cè)趥}庫里提供了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.安裝以下的依賴,windows用戶請(qǐng)以管理員用戶運(yùn)行cmd并依次執(zhí)行:
# pyautogui庫 pip install pyautogui # 讀取excel表格的庫 pip install xlrd==1.2.0 # 向計(jì)算機(jī)的剪貼板發(fā)送文本/從計(jì)算機(jī)剪貼板接收文本的庫 pip install pyperclip # 計(jì)算機(jī)視覺庫 pip install opencv-python # 圖像處理庫 pip install pillow
到此,成功安裝了5個(gè)庫
2.配合使用py腳本和xlsx文件
第一步
需要將搶課的每一步所需要點(diǎn)擊的圖標(biāo)/超鏈接在頭腦中想清楚
第二步
將搶課每一步的所需點(diǎn)擊的圖標(biāo)/超鏈接截圖,保存在和py腳本同一路徑下

打開excel表格,根據(jù)第一行提示在單元格中進(jìn)行輸入:

A列------備注(可填可不填)
B列------操作類型,目前包括:
- 1.左鍵單擊(循環(huán)直到找到圖片為止):意思就是如果沒有找到你設(shè)置的那張圖片,它就一直找下去,找不到就不停;你所設(shè)置的次數(shù)是找到成功的次數(shù)
- 2.輸入字符串
- 3.等待
- 4.熱鍵
- 5.左鍵單擊(無需找到圖片):找圖片不管找沒找到,就找那這么多次,次數(shù)=找到成功的次數(shù)+找到失敗的次數(shù)
C列------B列的參數(shù)
- 待點(diǎn)擊圖標(biāo)名(包括圖片后綴名,如.png)
- 等待的時(shí)間(秒)
- 輸入的字符串
- 熱鍵
D列------單擊重復(fù)次數(shù)
- 不填,默認(rèn)為1
- 若想無限單擊,填-1
按照你的選課步驟從第2行開始順序填寫excel表格的執(zhí)行步驟
此時(shí),保存excel表格
第三步
我們打開需要進(jìn)行操作的選課網(wǎng)頁
我們?cè)赾md下切換到腳本所在目錄
# 切換到D盤 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ú)一無二的標(biāo)記在截圖中并且將所要點(diǎn)擊的點(diǎn)放在qq截圖四個(gè)藍(lán)點(diǎn)的中央

- 如果遇到同一畫面中需要點(diǎn)擊的圖標(biāo)存在多個(gè)一樣的,沒有特征參照物,可以在那一步設(shè)置等待若干秒,手動(dòng)點(diǎn)擊圖標(biāo)
- 若未成功識(shí)別圖片,將循環(huán)執(zhí)行識(shí)別操作;手動(dòng)點(diǎn)擊圖標(biāo)成功,excel表格中中的指令也會(huì)跳到下一條
- 考慮到網(wǎng)絡(luò)延遲問題,建議合理利用等待功能
(2).蹲點(diǎn)撿漏
在搶課一次的基礎(chǔ)上套了一層死循環(huán)
巧妙利用f5、左鍵單擊(循環(huán)直到找到圖片為止)、左鍵單擊(無需找到圖片),可以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ù)提示填寫坐標(biāo)、操作
5.代碼
import pyautogui
import time
import xlrd
import pyperclip
# 定義鼠標(biāo)事件
# duration類似于移動(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:
# 獲取圖片名稱
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ù)二:蹲點(diǎn)等人退課
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("------歡迎使用自動(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ù)包含中文的讀寫問題
今天小編就為大家分享一篇解決python3 json數(shù)據(jù)包含中文的讀寫問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-05-05
python網(wǎng)絡(luò)編程學(xué)習(xí)筆記(五):socket的一些補(bǔ)充
前面已經(jīng)為大家介紹了python socket的一些相關(guān)知識(shí),這里為大家補(bǔ)充下,方便需要的朋友2014-06-06
django利用request id便于定位及給日志加上request_id
這篇文章主要介紹了django利用request id便于定位及給日志加上request_id的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用django具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧2018-08-08
python雙端隊(duì)列原理、實(shí)現(xiàn)與使用方法分析
這篇文章主要介紹了python雙端隊(duì)列原理、實(shí)現(xiàn)與使用方法,結(jié)合實(shí)例形式分析了Python雙端隊(duì)列的概念、原理、定義及使用方法,需要的朋友可以參考下2019-11-11
Python簡單實(shí)現(xiàn)詞云圖代碼及步驟解析
這篇文章主要介紹了Python簡單實(shí)現(xiàn)詞云圖代碼解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06
Python利用pyodbc庫將文件信息插入Access數(shù)據(jù)庫
在日常編程工作中,我們經(jīng)常需要處理文件和文件夾,所以本文將介紹如何使用Python編程語言和wxPython庫創(chuàng)建一個(gè)簡單的文件瀏覽器界面,使用戶能夠選擇文件夾并將文件信息插入到Access數(shù)據(jù)庫中,需要的可以參考下2023-08-08

