内容字号:默认大号超大号

段落设置:段首缩进取消段首缩进

字体设置:切换到微软雅黑切换到宋体

Python_Selenium学习笔记(三):元素定位方法

2018-09-11 22:05 出处:清屏网 人气: 评论(0

元素定位方法

想操作浏览器就要先定位浏览器中的元素,常用有8种定位方法

注意:无论使用什么方法,一定要确保定位元素方法的唯一性

以定位百度首页输入框为例

1、find_element_by_id(),通过元素的id属性定位

说明:.send_keys()方法是像输入框中输入内容,为演示效果使用

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_id("kw").send_keys("selenium")

2、find_element_by_name(),通过元素的name属性定位

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_name("wd").send_keys("selenium")

3、find_element_by_class_name(),通过元素的class属性定位

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_class_name("s_ipt").send_keys("selenium")

4、find_element_by_tag_name(),通过元素标签定位

注意:由于页面上有多个input标签,以下代码定位不会成功,只是演示代码写法

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_tag_name("input").send_keys("selenium")

5、find_element_by_link_text(),通过文本链接内容定位(如定位百度首页右上角的hao123)

说明:由于hao123是个文本链接不是输入框,所以使用click()方法起到点击的演示效果

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_link_text("hao123").click()

6、find_element_by_partial_link_text(),通过部分文本链接内容定位(如定位百度首页右上角的hao123)

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_partial_link_text("ao123").click()

7、find_element_by_xpath(),通过元素的路径位置定位元素

说明:

1、下面代码中input可以写成*(表示所有标签),但一般写具体标签名

2、下面代码中的id可以用任意有唯一值的属性替换,如[@autocomplete='off']

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_xpath("//input[@id='kw']").send_keys("selenium")

如果一个元素无法通过属性来定位时,我们可以通过它父级元素(上层)或爷爷级元素(上上层)来定位

说明:span为父元素,form为爷爷元素

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_xpath("//form[@id='form']/span/input").send_keys("selenium")

如果一个元素的兄弟元素标签与它一致,这时无法通过层级关系定位到,这种情况可以按产生的先后顺序来定位

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_xpath("//form[@id='form']/input[1]")
dr.find_element_by_xpath("//form[@id='form']/input[2]")
dr.find_element_by_xpath("//form[@id='form']/input[3]")

如果一个元素靠一个属性无法定位,我们可以根据多个属性结合定位

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_xpath("//input[@id='kw' and @name='wd']").send_keys("selenium")

根据元素所在路径定位

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_xpath("/html/body/div/div/div/div/div/form/span/input").send_keys("selenium")

8、find_element_by_css_selector(),与xpath定位类似,但语法更简洁

与xpath对比:

css用#表示id属性,如#kw

css用.表示class属性,如.s_ipt

css可以直接使用标签名,无需任何标识符,如input

css可以直接使用任意有唯一值的属性,如[autocomplete='off']

css根据元素定位时层级间使用>

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_css_selector("#kw").send_keys("selenium")
dr.find_element_by_css_selector(".s_ipt").send_keys("selenium")
dr.find_element_by_css_selector("input").send_keys("selenium")
dr.find_element_by_css_selector("[autocomptele='off']").send_keys("selenium")
dr.find_element_by_css_selector("form#form>span>input").send_keys("selenium")
分享给小伙伴们:
本文标签: PythonSelenium

相关文章

发表评论愿您的每句评论,都能给大家的生活添色彩,带来共鸣,带来思索,带来快乐。

CopyRight © 2015-2016 QingPingShan.com , All Rights Reserved.

清屏网 版权所有 豫ICP备15026204号