欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python實現(xiàn)自動搶課腳本的示例代碼

 更新時間:2021年12月13日 15:11:17   作者:DanteIoVeYou  
本文主要介紹了python實現(xiàn)自動搶課腳本的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

自動搶課腳本使用手冊

@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ù)包含中文的讀寫問題

    今天小編就為大家分享一篇解決python3 json數(shù)據(jù)包含中文的讀寫問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • python網(wǎng)絡(luò)編程學(xué)習(xí)筆記(五):socket的一些補充

    python網(wǎng)絡(luò)編程學(xué)習(xí)筆記(五):socket的一些補充

    前面已經(jīng)為大家介紹了python socket的一些相關(guān)知識,這里為大家補充下,方便需要的朋友
    2014-06-06
  • django利用request id便于定位及給日志加上request_id

    django利用request id便于定位及給日志加上request_id

    這篇文章主要介紹了django利用request id便于定位及給日志加上request_id的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用django具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧
    2018-08-08
  • python雙端隊列原理、實現(xiàn)與使用方法分析

    python雙端隊列原理、實現(xiàn)與使用方法分析

    這篇文章主要介紹了python雙端隊列原理、實現(xiàn)與使用方法,結(jié)合實例形式分析了Python雙端隊列的概念、原理、定義及使用方法,需要的朋友可以參考下
    2019-11-11
  • python隨機獲取列表中某一元素的方法

    python隨機獲取列表中某一元素的方法

    本文主要介紹了python隨機獲取列表中某一元素的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • Python簡單實現(xiàn)詞云圖代碼及步驟解析

    Python簡單實現(xiàn)詞云圖代碼及步驟解析

    這篇文章主要介紹了Python簡單實現(xiàn)詞云圖代碼解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-06-06
  • Python利用pyodbc庫將文件信息插入Access數(shù)據(jù)庫

    Python利用pyodbc庫將文件信息插入Access數(shù)據(jù)庫

    在日常編程工作中,我們經(jīng)常需要處理文件和文件夾,所以本文將介紹如何使用Python編程語言和wxPython庫創(chuàng)建一個簡單的文件瀏覽器界面,使用戶能夠選擇文件夾并將文件信息插入到Access數(shù)據(jù)庫中,需要的可以參考下
    2023-08-08
  • Python爬蟲技術(shù)

    Python爬蟲技術(shù)

    本文將要介紹的是python爬蟲基礎(chǔ)知識,感興趣的小伙伴一起來學(xué)習(xí)吧
    2021-08-08
  • python引入其他py文件或模塊

    python引入其他py文件或模塊

    本文主要介紹了python引入其他py文件或模塊,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • Python單元測試簡單示例

    Python單元測試簡單示例

    這篇文章主要介紹了Python單元測試,結(jié)合實例形式分析了Python單元測試的簡單定義、使用方法及相關(guān)操作注意事項,需要的朋友可以參考下
    2018-07-07

最新評論