溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python自動化如何實現(xiàn)登錄獲取圖片驗證碼功能

發(fā)布時間:2021-05-11 10:59:23 來源:億速云 閱讀:624 作者:小新 欄目:開發(fā)技術

小編給大家分享一下python自動化如何實現(xiàn)登錄獲取圖片驗證碼功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

Python主要用來做什么

Python主要應用于:1、Web開發(fā);2、數據科學研究;3、網絡爬蟲;4、嵌入式應用開發(fā);5、游戲開發(fā);6、桌面應用開發(fā)。

主要記錄一下:圖片驗證碼

1.獲取登錄界面的圖片

2.獲取驗證碼位置

3.在登錄頁面截取驗證碼保存

4.調用百度api識別(目前準確率較高的識別圖片api)

本次登錄的系統(tǒng)頁面,可以看到圖片驗證碼的位置

python自動化如何實現(xiàn)登錄獲取圖片驗證碼功能

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')#截取的驗證碼圖片保存為新的文件

上面我們已經把圖片保存到本地

這就是我們截取的驗證碼

python自動化如何實現(xiàn)登錄獲取圖片驗證碼功能

接下來要調用 百度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)

python自動化如何實現(xiàn)登錄獲取圖片驗證碼功能

這樣就識別出來 了,這個能識別正確我也是驚訝了
畢竟之前好多次都 識別的不準確
好!這樣 驗證碼就識別出來 惹,然后把識別的內容輸進框子里,點擊登錄就ok

以上是“python自動化如何實現(xiàn)登錄獲取圖片驗證碼功能”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI