您好,登錄后才能下訂單哦!
小編給大家分享一下python自動化如何實現(xiàn)登錄獲取圖片驗證碼功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
Python主要應用于:1、Web開發(fā);2、數據科學研究;3、網絡爬蟲;4、嵌入式應用開發(fā);5、游戲開發(fā);6、桌面應用開發(fā)。
主要記錄一下:圖片驗證碼
1.獲取登錄界面的圖片
2.獲取驗證碼位置
3.在登錄頁面截取驗證碼保存
4.調用百度api識別(目前準確率較高的識別圖片api)
本次登錄的系統(tǒng)頁面,可以看到圖片驗證碼的位置
from selenium import webdriver import time from PIL import Image base_url = '***********' browser = webdriver.Chrome() browser.maximize_window() browser.implicitly_wait(10) browser.get(base_url) # (1)登錄頁面截圖 browser.save_screenshot("D:/pic.png")#可以修改保存地址 # (2)基操 browser.find_element_by_name("username").send_keys("gxx") browser.find_element_by_name("password").send_keys("123456") time.sleep(2) # (3)獲取圖片驗證碼坐標 code_ele = browser.find_element_by_xpath("//*[@id='app']/div/div[1]/form/div[3]/div/div/div[2]/div/img") print("驗證碼的坐標為:", code_element.location)#控制臺查看{'x': 1086, 'y': 368} print("驗證碼的大小為:", code_element.size)# 圖片大小{'height': 40, 'width': 110} # (4)圖片4個點的坐標位置 left = code_ele.location['x']#x點的坐標 top = code_ele.location['y']#y點的坐標 right = code_ele.size['width']+left#上面右邊點的坐標 down = code_ele.size['height']+top#下面右邊點的坐標 image = Image.open('D:/pic.png') # (4)將圖片驗證碼截取 code_image = image.crop((left, top, right, height)) code_image.save('D:/pic1.png')#截取的驗證碼圖片保存為新的文件
上面我們已經把圖片保存到本地
這就是我們截取的驗證碼
接下來要調用 百度ocr識別
鏈接: https://ai.baidu.com/docs#/
然后可以選擇通用文字識別或者 高精度版本,這個 看個人選擇,不過驗證碼識別還是選擇高精度 版本(也不一定識別的出來 大家還是佛吧,測試的時候讓開發(fā)把驗證碼去掉嘻嘻)
自己去申請一個百度云賬號,然后開通文字識別服務…就醬
新建一個py文件
#百度ocr提供了模板,我們直接復制就ok #下載通用文字識別的python sdk,一定要放在你寫的代碼的文件夾下面 from aip import AipOcr from os import path def baiduOCR(picfile,outfile):#picfile:圖片文件名 outfile:輸出文件 filename = path.basename(picfile)#圖片名稱 #百度提供 """ 你的 APPID AK SK """ APP_ID = ''#這是你產品服務的appid API_KEY = ''#這是你產品服務的appkey SECRET_KEY = ''#這是你產品服務的secretkey client = AipOcr(APP_ID, API_KEY, SECRET_KEY) i = open(picfile, 'rb') img = i.read() print("正在識別圖片:\t" + filename) """ 調用通用文字識別(高精度版) """ message = client.basicAccurate(img) print("識別成功!") i.close() with open(outfile, 'a+') as fo:#這邊是寫進.txt文件 fo.writelines("*" * 60 + '\n')#搞點花里胡哨的做區(qū)分 fo.writelines("識別圖片:\t" + filename + "\n" * 2) fo.writelines("文本內容:\n") # 輸出文本內容 for text in message.get('words_result'):#識別的內容 fo.writelines(text.get('words') + '\n') fo.writelines('\n' * 2) print("文本導出成功!") print() if __name__ == '__main__' : outfile = 'D:/export1.txt'#保存的文件 baiduOCR('D:/pic1.png', outfile) print('圖片文本提取結束!文本輸出結果位于 %s 文件中。' % outfile)
這樣就識別出來 了,這個能識別正確我也是驚訝了
畢竟之前好多次都 識別的不準確
好!這樣 驗證碼就識別出來 惹,然后把識別的內容輸進框子里,點擊登錄就ok
以上是“python自動化如何實現(xiàn)登錄獲取圖片驗證碼功能”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。