元素定位有不同的寫法,而元素組定位僅僅只是增加了一個索引取值的方式的進行定位,后續會有介紹到具體的用法,這里介紹時用到的例子不一,主要是告訴各位用法是怎么樣的,
具體的實體,最后將會有一個小實戰,會給出專案地址,各位可自行進行撰寫,寫完可以發給博主看看,博主微信qing_an_an,水軍一枚,歡迎騷擾,
元素定位

name方法

我們打開瀏覽器搜索https://baidu.com,我們以百度為例,
這里很明顯有id,有class,有name定位方法給到你,我們這里先講述name元素定位方法
from selenium import webdriver
import time
fox = webdriver.Firefox()
fox.get('https://baidu.com')
fox.find_element_by_name('wd').send_keys('北海有漁啊')
time.sleep(2)
fox.quit()
這里我在定位方式后面加上了.send_keys()方法,因為這是輸入框,需要輸入內容的,所以就加上了,也是為了效果明顯有些,自己跑一邊看看效果就能秒懂!
id方法
上面我們用百度的例子定位了輸入框,那么我們這回來定位搜索按鈕并點擊它,

from selenium import webdriver
import time
fox = webdriver.Firefox()
fox.get('https://baidu.com')
fox.find_element_by_name('wd').send_keys('北海有漁啊')
fox.find_element_by_id('su').click()
time.sleep(2)
fox.quit()
這樣我們就能開啟代碼百度搜索內容了,是不是很神奇,自己動手 嘗試吧,
class_name方法
本例還是采用百度進行舉例,百度是可以幫我們學習到很多的東西的哦!!

from selenium import webdriver
import time
fox = webdriver.Firefox()
fox.get('https://baidu.com')
fox.find_element_by_class_name('s_ipt').send_keys('北海有漁啊')
fox.find_element_by_id('su').click()
time.sleep(2)
fox.quit()
xpath方法
xpath方法定位起來相對便捷一些,粘貼復制,當然這是最普通的xpath,這里介紹兩種xpath方法!

from selenium import webdriver
fox = webdriver.Firefox()
fox.get('https://baidu.com')
fox.find_element_by_xpath('//*[@id="kw"]').send_keys('北海有漁啊')
fox.find_element_by_id('su').click()
第二種也許你會看不懂,看圖你就懂了!這種方法我覺的還是比較簡便的,xpath萬能的定位方式!!!

from selenium import webdriver
fox = webdriver.Firefox()
fox.get('https://baidu.com')
fox.find_element_by_xpath('//*[@id="kw"]').send_keys('北海有漁啊')
fox.find_element_by_xpath('//*[@value="百度一下"]').click()
這里我們定位的是value值等于百度一下,你復制xpath你會發現復制下來的是'//*[@id="su"]')這樣的寫法,所以這里會稍加不同,也可以在不同的場景中使用,比如:很多ID為su的時候,value值不同,你可以不用find_by_elements的方法進行定位,直接使用手寫的xpath方法進行定位,xpath定位不止這兩種,在后續的程序中會一一具體展示,
tag_name方法
此方法用于定位標簽名,單獨配合find_element例子讓我一頓好找,

from selenium import webdriver
fox = webdriver.Firefox()
fox.get('https://www.taobao.com/')
fox.find_element_by_tag_name('input').send_keys('奧運')
fox.quit()
標簽名定位的方式方法用的比較的少,一般性常用的就是id,name,xpath,
link_text方法
此方法可以用于文字定位,唯一不好的一點就是需要定位的是一段完整的名字,否則無法定位到,我個人不是很喜歡這個定位方法,

from selenium import webdriver
fox = webdriver.Firefox()
fox.get('https://xueshu.baidu.com/')
fox.find_element_by_link_text('這里有你想知道的關于文獻互助的一切').click()
fox.quit()
此方法太繁瑣了,為了找尋例題,封存了多少張圖,勉強放出這一張出來...
partial_link_text方法
這個方法先對上個方法那就是簡潔的太多了,便捷!!!此方法不需要全部的文本資訊就可以定位,但是這些都會有一定的弊端,就是漢字很多的時候難免會出現重復的,

from selenium import webdriver
fox = webdriver.Firefox()
fox.get('https://baidu.com')
fox.find_element_by_partial_link_text('hao').click()
fox.quit()
css_selector方法
css定位方法,跟xpath類似,

from selenium import webdriver
fox = webdriver.Firefox()
fox.get('https://baidu.com')
fox.find_element_by_css_selector('#kw').send_keys('北海有漁啊')
fox.quit()
By方法
看個人喜歡哪一種,這個方法需要匯入一個類,其他的定位方式與find_element系列完全一致,就是準確的元素定位一塊寫法有一些別致,此例子也是百度輸入框的例子,我也就不附圖了,君若喜歡可以By.XPATH,By.NAME等,后面的例題中舉出了不需要倒包,不用By的類似方法,
from selenium import webdriver
from selenium.webdriver.common.by import By
fox = webdriver.Firefox()
fox.get('https://baidu.com')
fox.find_element(By.ID,'kw').send_keys('北海有漁啊')
元素組

class_name方法
之所以講這個是因為沒有找到合適的例子來說,我會盡量多少幾個講解一下,明白一個其他的都是類似的寫法,舉一反三!!!

這里有很多的a標簽,里面有很多的class,這些class在一個div里面,這里我們就可以看作一個串列,你定位到了class后,根據索引進行取值,從而達到定位的效果,索引取值從0開始,所以這里取0時定位的是新聞,取1時定位的時hao123
from selenium import webdriver
fox = webdriver.Firefox()
fox.get('https://baidu.com')
fox.find_elements_by_class_name('mnav.c-font-normal')[0].click()
fox.quit()
這里還是有幾點要說的:
1、元素組取值有空格時你可以只取前面的幾個值,這里就是mnav,再通過索引也是可以定位到的,
2、遇到空格,你礙于強迫癥非要加上后面的,那就跟我一樣的寫法,加上.就好了,將前后連接起來,
3、這里也可以用我上一章所說的,用文本值進行定位,所以說蘿卜青菜各有所愛,
xpath方法
這里我用的是一個學習網址的一個例子,找了半天網上大部分都是class類的元素組,太苦了我!!!

from selenium import webdriver
fox = webdriver.Firefox()
fox.get('https://www.w3school.com.cn/python/python_inheritance.asp')
fox.find_elements_by_xpath('/html/body/div/div[3]/div[1]/ul[1]/li[1]/a')[0].click()
其他的用法大同小異,這里介紹這兩種,準確的說看第一種是完全可以看懂用法,
下拉串列定位
下拉串列常見的前端表現形式:Select+Option 和 ul+li,這種方法可以用,到后面講到滑鼠鍵盤操作的時候,有一些下拉串列定位可以直接用滑鼠來實作了,

如這個例子,12306購票網站的,看圖,我想選中時間,這是一個select標簽,我們需要匯入一個類才能定位到,并且select給了三種定位方法(實際不止三種,這里我們用的上的只有兩種)
from selenium import webdriver
from selenium.webdriver.support.ui import Select
fox = webdriver.Firefox()
fox.get('https://kyfw.12306.cn/otn/leftTicket/init?linktypeid=dc')
fox.find_element_by_id('qd_closeDefaultWarningWindowDialog_id').click()
# 先定位select元素
ele = fox.find_element_by_id('cc_start_time')
# 配合方法進行定位值
# Select(ele).select_by_value('00000600')
Select(ele).select_by_index(1)
可以取value值,可以用索引取值,都是可以直接修改這個時間的,
專案實戰
元素定位中除了文中介紹的方法,更有一些其他的方法,一起看看,會在文中指出來,
專案地址:http://8.129.162.225:8080/
import time
from selenium import webdriver
fox = webdriver.Firefox()
fox.get('http://8.129.162.225:8080/')
# 等待兩秒渲染界面
time.sleep(2)
# 點擊注冊
"""此處元素定位方式寫法有一定的不同"""
fox.find_element('class name','am-btn-primary.btn.am-fr').click()
time.sleep(2)
# 定位輸入框
fox.find_element('name','accounts').send_keys('qinganan')
fox.find_element('name','pwd').send_keys('1234567')
time.sleep(10)
# 這里需要自己手動輸入驗證碼
# 勾選同意按鈕
fox.find_element('class name','am-icon-checked').click()
# 點擊注冊
fox.find_element('xpath','/html/body/div[4]/div/div/div/div[2]/div[1]/div/div[1]/form/div[5]/button').click()
fox.close()
fox.quit()
這里是一個簡單的注冊專案實戰,不過程序中驗證碼一處需要自己手動輸入,自動輸入也是可以的,不過存在誤差很容易識別錯誤,并且需要借助其他平臺的介面才可以,所以這里直接手動輸入的實在,
不過可以放心的是,企業中會讓開發屏蔽掉的,因為自動化中有一準則拋棄實作難度大的,雖然此項技術不算難度大,要想準確識別,需要企業花一定資金購買其他平臺的介面,最直接的操作就是開發屏蔽掉,然后人為對此項進行校驗,
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/301082.html
標籤:其他
