元素定位(1)

元素定位

元素的定位应该是自动化测试的核心,要想操作一个元素,首先应该识别这个元素。

webdriver提供了一系列的元素定位方法,常用的有以下几种

  • id
  • name
  • class name
  • link text
  • partial link text
  • tag name
  • xpath
  • css selector

案例:打开百度首页,在搜索框自动输入“Selenium我要自学网”关键词,然后点击搜索按钮,查看搜索页面。

id与name 定位

from  selenium import webdriver

from time import sleep

 

driver=webdriver.Firefox()

driver.get("http://www.baidu.com")

 

 

driver.find_element_by_id("kw").send_keys("Selenium我要自学网")

driver.find_element_by_name("wd").send_keys("Selenium我要自学网")

 

sleep(2)

driver.find_element_by_id("su").click()

tag_name定位

案例:打开我要自学网页面,在用户名输入框输入用户名“selenium”

from  selenium import webdriver
from  time import sleep
 
driver=webdriver.Firefox()
 
driver.get("http://www.XXX.com")
 
#定位标签名为input的元素
driver.find_element_by_tag_name("input").send_keys("selenium")
 
#获取页面所有标签名称为“input”的标签。
driver.find_elements_by_tag_name("input")[0].send_keys("selenium")
 
sleep(3)
 
driver.quit()

 

 

class_name定位

根据标签中属性class来进行定位的一种方法

from  selenium import webdriver
from  time import sleep
 
driver=webdriver.Firefox()
 
driver.get("http://www.baidu.com")
 
driver.find_element_by_class_name("s_ipt").send_keys("Selenium 我要自学网")
sleep(2)
 
driver.find_element_by_id("su").click()
sleep(3)
 
driver.quit()

link_text定位

link_text定位就是根据超链接文字进行定位。

from selenium import webdriver
from time import sleep
 
driver=webdriver.Firefox()
 
driver.get("http://www.XXX.net/")
 
driver.find_element_by_link_text('程序开发').click()
sleep(3)

#模糊搜索
driver.find_element_by_partial_link_text('神秘面纱').click()

 

XPath定位

XPath即为XML路径语言,它是一种用来确定XML文档中某部分位置的语言。XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力。

xpath绝对与相对定位
from selenium import webdriver
from time import sleep
 
driver=webdriver.Firefox()
 
driver.get("http://www.baidu.com")
 
# 绝对路径定位
driver.find_element_by_xpath("/html/body/div[2]/div[1]/div/div[1]/div/form/span[1]/input").send_keys("51zxw")
 
# 利用元素熟悉定位--定位到input标签中为kw的元素
driver.find_element_by_xpath("//input[@id='kw']").send_keys("Selenium")
 
# 定位input标签中name属性为wd的元素
driver.find_element_by_xpath("//input[@name='wd']").send_keys("Selenium")
 
# 定位所有标签元素中,class属性为s_ipt的元素
driver.find_element_by_xpath("//*[@class='s_ipt']").send_keys("Python3")
 
driver.find_element_by_id('su').click()
 
sleep(3)
driver.quit()

 

 

 

 

 

Xpath层级与逻辑定位

from selenium import webdriver
from time import sleep
 
driver=webdriver.Firefox()
 
driver.get("http://www.XXX.net/")
#层级和属性结合定位--自学网首页输入用户和名密码
driver.find_element_by_xpath("//form[@id='loginForm']/ul/input[1]").send_keys("51zxw")
driver.find_element_by_xpath("//form[@id='loginForm']/ul/input[2]").send_keys("66666")
 
#逻辑运算组合定位
driver.find_element_by_xpath("//input[@class='loinp' and @name='username']").send_keys("51zxw")
 
sleep(3)
driver.quit()

 

Css定位

Selenium极力推荐使用CSS 定位,而不是XPath来定位元素,原因是CSS 定位比XPath 定速度快,语法也更加简洁。

CSS常用定位方法

  1. find_element_by_css_selector()
  2. #id id选择器根据id属性来定位元素
  3. .class  class选择器,根据class属性值来定位元素
  4. [attribute='value'] 根据属性来定位元素
  5. element>element 根据元素层级来定位 父元素>子元素

 

 

 

 

 

from selenium import webdriver

from time import sleep

 

driver=webdriver.Firefox()

 

driver.get("http://www.baidu.com")

 

#根据id来定位

driver.find_element_by_css_selector('#kw').send_keys("Selenium 我要自学网")

 

#根据class定位

driver.find_element_by_css_selector('.s_ipt').send_keys('python')

 

#通过属性来定位

driver.find_element_by_css_selector("[autocomplete='off']").send_keys("selenium")

 

sleep(2)

driver.find_element_by_id('su').click()

 

driver.get("http://www.XXX.net")

 

#通过元素层级来定位

driver.find_element_by_css_selector("form#loginForm>ul>input").send_keys("51zxw")

 

sleep(2)

driver.quit()

猜你喜欢

转载自www.cnblogs.com/zf612326/p/9299962.html