亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

【python入門學習】Selenium庫的使用

系統 1835 0

一、什么是Selenium

selenium 是一套完整的web應用程序測試系統,包含了測試的錄制(selenium IDE),編寫及運行(Selenium Remote Control)和測試的并行處理(Selenium Grid)。Selenium的核心Selenium Core基于JsUnit,完全由JavaScript編寫,因此可以用于任何支持JavaScript的瀏覽器上。

selenium可以模擬真實瀏覽器,自動化測試工具,支持多種瀏覽器,爬蟲中主要用來解決JavaScript渲染問題。

二、selenium基本使用

這里要說一下比較重要的PhantomJS,PhantomJS是一個而基于WebKit的服務端JavaScript API,支持Web而不需要瀏覽器支持,其快速、原生支持各種Web標準:Dom處理,CSS選擇器,JSON等等。PhantomJS可以用用于頁面自動化、網絡監測、網頁截屏,以及無界面測試。

聲明瀏覽器對象

selenium支持很多的瀏覽器,但是如果想要聲明并調用瀏覽器則需要:

            
              from selenium import webdriver

browser = webdriver.Chrome()
browser = webdriver.Firefox()
            
          

這里只寫了兩個例子,當然了其他的支持的瀏覽器都可以通過這種方式調用

訪問頁面

            
              from selenium import webdriver

browser = webdriver.Chrome()
browser.get("http://www.baidu.com")
print(browser.page_source)
browser.close() 
            
          

上述代碼運行后,會自動打開Chrome瀏覽器,并登陸百度打印百度首頁的源代碼,然后關閉瀏覽器。

查找元素

單個元素查找

            
              from selenium import webdriver

browser = webdriver.Chrome()
browser.get("http://www.taobao.com")
input_first = browser.find_element_by_id("q")
input_second = browser.find_element_by_css_selector("#q")
input_third = browser.find_element_by_xpath('//*[@id="q"]')
print(input_first)
print(input_second)
print(input_third)
browser.close()
            
          

這里我們通過三種不同的方式去獲取響應的元素,第一種是通過id的方式,第二個中是CSS選擇器,第三種是xpath選擇器,結果都是相同的。
結果如下:

這里列舉一下常用的查找元素方法:

find_element_by_name
find_element_by_id
find_element_by_xpath
find_element_by_link_text
find_element_by_partial_link_text
find_element_by_tag_name
find_element_by_class_name
find_element_by_css_selector

下面這種方式是比較通用的一種方式:這里需要記住By模塊所以需要導入
from selenium.webdriver.common.by import By

            
              from selenium import webdriver
from selenium.webdriver.common.by import By

browser = webdriver.Chrome()
browser.get("http://www.taobao.com")
input_first = browser.find_element(By.ID,"q")
print(input_first)
browser.close()
            
          

當然這種方法和上述的方式是通用的,browser.find_element(By.ID,"q")這里By.ID中的ID可以替換為其他幾個

多個元素查找

其實多個元素和單個元素的區別,舉個例子:find_elements,單個元素是find_element,其他使用上沒什么區別,通過其中的一個例子演示:

            
              from selenium import webdriver

browser = webdriver.Chrome()
browser.get("http://www.taobao.com")
lis = browser.find_elements_by_css_selector('.service-bd li')
print(lis)
browser.close()
            
          

這樣獲得就是一個列表

【python入門學習】Selenium庫的使用_第1張圖片

?

當然上面的方式也是可以通過導入from selenium.webdriver.common.by import By 這種方式實現:

lis = browser.find_elements(By.CSS_SELECTOR,'.service-bd li')

同樣的在單個元素中查找的方法在多個元素查找中同樣存在:
find_elements_by_name
find_elements_by_id
find_elements_by_xpath
find_elements_by_link_text
find_elements_by_partial_link_text
find_elements_by_tag_name
find_elements_by_class_name
find_elements_by_css_selector


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。。?/p>

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 日韩亚洲欧美在线爱色 | 亚洲综合亚洲综合网成人 | 欧美亚洲精品一区二三 | 精品欧美一区手机在线观看 | 香蕉视频在线免费播放 | 伊人资源 | 四虎网站1515hh四虎 | 国产69精品久久久久99不卡 | 亚洲国产欧美一区 | 激情国产白嫩美女在线观看 | 中国日韩欧美中文日韩欧美色 | 免费观看黄色的网站 | 天天躁狠狠躁 | 久久久久久国产精品免费免费 | 成人午夜网站 | 国产日产久久高清欧美一区 | 久久99亚洲精品久久频 | 六月色| 夜夜摸天天操 | 99亚洲精品| 久久亚洲伊人 | 一级毛片在线观看免费 | 国产亚洲高清在线精品99 | 国产精品一区二区四区 | 色老板女色狠xx网 | 四虎国产永久免费久久 | 中国一级特黄特级毛片 | 中文字幕不卡在线高清 | 国产精品欧美一区二区在线看 | 国产无套免费网站 | 国产小视频精品 | 又黄又爽又成人免费视频 | 97免费视频在线 | 国产精品久久久久久久久久久不卡 | 欧美99热| 亚洲色妞 | 久久国产免费观看精品1 | 国产午夜精品久久久久免费视 | 99pao在线视频精品免费 | 狠狠88综合久久久久综合网 | 亚洲欧美日韩综合 |