使用Python爬取彈出窗口信息的實例
此文僅當學習筆記用.
這個實例是在Python環境下如何爬取彈出窗口的內容,有些時候我們要在頁面中通過點擊,然后在彈出窗口中才有我們要的信息,所以平常用的方法也許不行.
這里我用到的是Selenium這個工具, 不知道的朋友可以去搜索一下. 但是安裝也是很費事的. 而且我用的瀏覽器是firefox,不用IE是因為好像新版的IE在Selenium下有問題,我也是百思不得其解, 網上也暫時沒找到好的辦法.
from selenium import webdriverfrom selenium.webdriver.common.keys import Keysimport os,time
browser=webdriver.Firefox(executable_path=’d:Anacondapkgsspyder-3.2.8-py36_0geckodriver.exe’) #括號中的也是非典型的安裝firefox驅動的方法,常規的方法我一直試的不行,但這種方法包管行.browser.get(’http://XXX.XXX.com/fenxi/yazhi-734155’) #輸入你的目標網址time.sleep(3) #打開網址后休息3秒鐘,可用可不用browser.find_element_by_xpath(’//*[@id='6']/td[4]’).click() #找到想要點擊的元素,然后進行點擊動作,讓窗口彈出來handle=browser.current_window_handle #獲得當前窗口,也就是彈出的窗口句柄,什么是句柄我也解釋不清楚,反正它代表當前窗口browser.switch_to_window(handle) #轉到當前彈出窗口s=browser.find_element_by_xpath(’//*[@id='tipdiv']/div[2]/table/tbody’) #找到裝有你要信息的元素print(s.text) #打印文本內容time.sleep(2) #休息2秒,讓瀏覽器喘口氣browser.find_element_by_xpath(’//*[@id='link106']’).click() #最后關掉彈出窗口. 這又是一個非典型方法,我是直接找到小窗口的叉叉來點擊關掉了,實際上Selinium有關閉當前窗口的方法,也就是close()或者quit(),但問題是搞來搞去不行啊?我的理解是目前的窗口依然是那個彈出的窗口,但handle.close等其它方法都不行. 所以我干脆用這樣的方法,找到叉叉的元素,然后點擊.
最后找元素我還是喜歡用xpath,有個小竅門,那就是在瀏覽器的開發者工具那里面,找到需要元素的元代碼,然后右鍵選擇Copy Xpath就有了,相當方便.
補充知識:python自動化測試中,點擊【查看】按鈕,彈窗出不來怎么辦?
一、在用python寫UI自動化測試的時候,可能會遇到明明用.click()點擊了【查看】按鈕,但是彈窗彈不出來;
遇到這個問題的時候,不妨可以試試模擬鍵盤的操作,利用.send_keys(Keys.ENTER)便可以解決這個問題;
代碼:
driver.find_element_by_xpath(“//*[@id=’main’]/div/div[3]/div/div/div[2]/div/div[2]/div[2]/div/div[2]/table/tbody/tr/td[9]/div/button/span”).click()
修改為:
driver.find_element_by_xpath(“//*[@id=’main’]/div/div[3]/div/div/div[2]/div/div[2]/div[2]/div/div[2]/table/tbody/tr/td[9]/div/button/span”).send_keys(Keys.ENTER)
以上這篇使用Python爬取彈出窗口信息的實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。
相關文章: