詳解Python自動化中這八大元素定位
一、find_element_by_id()
find_element_by_id()
1.從上面定位到的元素屬性中,可以看到有個id屬性:id=“kw”,這裡可以通過它的id屬性定位到這個元素。
2.定位到搜索框後,用send_keys()方法,就可以輸入文本。
from selenium import webdriver driver = webdriver.Firefox() driver.get("http://www.baidu.com") # 通過id定位百度輸入框,並輸入'python' ss = driver.find_element_by_id('kw') ss.send_keys('python')
二、find_element_by_name()
find_element_by_name()
1.從上面定位到的元素屬性中,可以看到有個name屬性:name=“wd”,這裡可以通過它的name屬性單位到這個元素。
說明:這裡運行後會報錯,說明這個搜索框的name屬性不是唯一的,無法通過name屬性直接定位到輸入框
from selenium import webdriver driver = webdriver.Firefox() driver.get("http://www.baidu.com") # 通過name定位百度輸入框,並輸入'python' ss = driver.find_element_by_name('wd') ss.send_keys('python')
三、find_element_by_class_name()
find_element_by_class_name()
1.從上面定位到的元素屬性中,可以看到有個class屬性:class=“s_ipt”,這裡可以通過它的class屬性定位到這個元素。
from selenium import webdriver driver = webdriver.Firefox() driver.get('http://www.baidu.com') #通過class定位百度輸入框,並輸入'python' driver.find_element_by_class_name('s_ipt').send_keys('python')
四、find_element_by_tag_name()
find_element_by_tag_name()
1.從上面定位到的元素屬性中,可以看到每個元素都有tag(標簽)屬性,如搜索框的標簽屬性,就是最前面的input。
2.很明顯,在一個頁面中,相同的標簽有很多,所以一般不用標簽來定位。以下例子,僅供參考和理解,運行肯定報錯。
from selenium import webdriver driver = webdriver.Firefox() driver.get('http://www.baidu.com') #通過tag(標簽)定位百度輸入框,並輸入'python' ss = driver.find_element_by_tag_name('input') ss.send_keys('python')
五、find_element_by_link_text()
1.定位百度頁面上”hao123″這個按鈕
查看頁面元素:
<a class="mnav" target="_blank" href="http://www.hao123.com" rel="external nofollow" >hao123</a>
2.從元素屬性可以分析出,有個href = “http://www.hao123.com
說明它是個超鏈接,對於這種元素,可以用以下方法:
from selenium import webdriver driver = webdriver.Chrome() driver.get('http://www.baidu.com') #通過tlink(超鏈接)定位百度輸入框,並點擊 driver.find_element_by_link_name('hao123').click()
六、find_element_by_partial_link_text()
1.有時候一個超鏈接它的字符串可能比較長,如果輸入全稱的話,會顯示很長,這時候可以用一模糊匹配方式,截取其中一部分字符串就可以瞭
2.如“hao123”,隻需輸入“ao123”也可以定位到
from selenium import webdriver driver = webdriver.Chrome() driver.get('http://www.baidu.com') #通過partial_link定位百度輸入框,並點擊(partial_link是一種模糊匹配的方式) driver.find_element_by_partial_link_name('hao123').click()
七、find_element_by_xpath()
1.以上定位方式都是通過元素的某個屬性來定位的,如果一個元素它既沒有id、name、class屬性也不是超鏈接,這麼辦呢?或者說它的屬性很多重復的。這個時候就可以用xpath解決。
2.xpath是一種路徑語言,跟上面的定位原理不太一樣,首先第一步要先學會查看一個元素的xpath。
- 對於谷歌瀏覽器來說,有自己 的xpath解析工具:鼠標移到需要查看的html源碼上,右擊
- 選擇copy
- copy xpath,就是源碼的xpath路徑
from selenium import webdriver driver = webdriver.Chrome() driver.get('http://www.baidu.com') #通過xpath地址定位百度輸入框,並點擊(xpath地址即為賦值過來的地址) driver.find_element_by_xpath('//*[@id="s-top-left"]/a[2]').click()
八、find_element_by_css_selector()
1.css是另外一種語法,比xpath更為簡潔,但是不太好理解。這裡先學會如何用工具查看,後續的教程再深入講解
- 對於谷歌瀏覽器來說,同樣有自己 的css解析工具:鼠標移到需要查看的html源碼上,右擊
- 選擇copy
- copy selector,就是源碼的css路徑
from selenium import webdriver driver = webdriver.Chrome() driver.get('http://www.baidu.com') #通過css地址定位百度輸入框,並點擊 driver.find_element_by_xpath('#s-top-left > a:nth-child(2)').click()
總結:
到此這篇關於詳解Python自動化中這八大元素定位的文章就介紹到這瞭,更多相關Python元素定位內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- python自動化八大定位元素講解
- Python腳本Selenium及頁面Web元素定位詳解
- Python語言中的Selenium環境搭建
- 全網最全python庫selenium自動化使用詳細教程
- Python selenium 八種定位元素的方式