Python實現(xiàn)自動簽到腳本功能
實訓(xùn)課期間忙里偷閑的學(xué)習(xí)了python的selenium包,唯一一點不好是要自己去查英文文檔,明擺著欺負(fù)我這種英語不好的,想著用谷歌翻譯一下,代碼也給我翻譯了,不知道是幾個意思。
大二的時候就讓我們做自動簽到腳本,說用JS可以寫一下,但是說著說著就給忘了,現(xiàn)在學(xué)了python后又想起來要寫一個自動簽到的腳本,不得不佩服python的強大,短短二十行左右的代碼就實現(xiàn)了,雖然說腳本還需要手動操作去運行,以后還是可以慢慢優(yōu)化的。
開發(fā)環(huán)境 : Windows10 + sublime(編輯器裝好python環(huán)境)
selenium的開發(fā)文檔網(wǎng)址(英語好的可以直接看這個,寫的很詳細(xì)):http://selenium-python.readthedocs.io/
因為實現(xiàn)的時候使用的是谷歌瀏覽器,在運行腳本時需要下載一個chromedriver.exe,下載地址為(注意根據(jù)自己的谷歌瀏覽器的版本來下載):http://npm.taobao.org/mirrors/chromedriver/
可以在里面找到符合自己瀏覽器版本的chromedriver,我的谷歌版本為67.0.3396.99,下載的是 2.40/ 下的最新版,下載之后將解壓后的.exe文件放到PATH中,這里我直接將文件放入了我的python36文件下,這樣就不用配置PATH了。
首先在dos中輸入下面的命令,下載selenium包 :
pip install selenium
然后就可以開始寫具體的代碼了,首先導(dǎo)入webdriver與time,其中time用于延時,以保證網(wǎng)頁加載完成。
# 方便延時加載 import time from selenium import webdriver # 模擬瀏覽器打開網(wǎng)站 browser = webdriver.Chrome() browser.get('https://www.ctguqmx.com') # 將窗口最大化 browser.maximize_window() # 根據(jù)路徑找到按鈕,并模擬進行點擊 browser.find_element_by_xpath('/html/body/div[1]/div/div[4]/span/a[1]').click() # 延時2秒,以便網(wǎng)頁加載所有元素,避免之后找不到對應(yīng)的元素 time.sleep(2) # 格式是PEP8自動轉(zhuǎn)的 # 這里是找到輸入框,發(fā)送要輸入的用戶名和密碼,模擬登陸 browser.find_element_by_xpath( "http://*[@id='aw-login-user-name']").send_keys("賬號") browser.find_element_by_xpath( "http://*[@id='aw-login-user-password']").send_keys("密碼") # 在輸入用戶名和密碼之后,點擊登陸按鈕 browser.find_element_by_xpath("http://*[@id='login_submit']").click() time.sleep(2) # 點擊登陸后的頁面中的簽到,跳轉(zhuǎn)到簽到頁面 browser.find_element_by_xpath("/html/body/div[1]/div/div[5]/a").click() time.sleep(2) # 點擊簽到,實現(xiàn)功能 browser.find_element_by_xpath("http://*[@id='qd_button']").click() time.sleep(2) # 這個print其實沒事什么用,如果真的要測試腳本是否運行成功,可以用try來拋出異常 print("簽到成功") # 腳本運行成功,退出瀏覽器 browser.quit()
以上實現(xiàn)了自動簽到的功能,不需要自己動手打開網(wǎng)頁了,直接運行腳本就可以實現(xiàn)簽到。
最后就是在寫腳本的時候遇到的小問題,昨天寫腳本的時候?qū)iT下了一個phantomjs,以前selenium還是支持的,使用phantomjs可以不需要瀏覽器就可以實現(xiàn)自動簽到,昨天寫的時候,上面報錯,說phantomjs被棄用了。
還有就是使用瀏覽器模擬登陸的時候總是報錯 : get() missing 1 required positional argument: 'url' ,然后下載chromedriver之后就好了。
在之前還嘗試過使用火狐瀏覽器去實現(xiàn)自動簽到,火狐也需要下載一個geckodriver.exe,下載之后也是要去編輯PATH,為了方便就直接把geckodriver.exe放在了python36的文件夾下,但是這個要求好像挺多的,我的火狐和geckodriver都是最新版,他還是會報錯,不讓打開火狐,后來我就選了chrome(還是谷歌大法好)。
總結(jié)
到此這篇關(guān)于Python實現(xiàn)自動簽到腳本的文章就介紹到這了,更多相關(guān)Python自動簽到腳本內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Pytorch 計算誤判率,計算準(zhǔn)確率,計算召回率的例子
今天小編就為大家分享一篇Pytorch 計算誤判率,計算準(zhǔn)確率,計算召回率的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-01-01用python刪除java文件頭上版權(quán)信息的方法
在使用他人代碼時,為不保留文件頭部版權(quán)信息,需要一個個刪掉,下面是用python刪除java文件頭上的版權(quán)信息的方法2014-07-07用python實現(xiàn)操縱mysql數(shù)據(jù)庫插入
大家好,本篇文章主要講的是用python實現(xiàn)操縱mysql數(shù)據(jù)庫插入,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下2022-01-01Keras自動下載的數(shù)據(jù)集/模型存放位置介紹
這篇文章主要介紹了Keras自動下載的數(shù)據(jù)集/模型存放位置介紹,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06Python對圖片進行resize、裁剪、旋轉(zhuǎn)、翻轉(zhuǎn)問題
這篇文章主要介紹了Python對圖片進行resize、裁剪、旋轉(zhuǎn)、翻轉(zhuǎn)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05python 實用工具狀態(tài)機transitions
這篇文章主要介紹了python 實用工具狀態(tài)機transitions的使用,幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下2020-11-11