zoukankan      html  css  js  c++  java
  • Python_Selenium学习笔记(3)-元素定位方法

    元素定位方法

    想操作浏览器就要先定位浏览器中的元素,常用有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")
  • 相关阅读:
    cityscapes和Mapillary Vistas两种不同分割数据集的label映射
    探究Z-Order
    Java ——对Swing、AWT和SWT的认识 原创
    UOJ-581 NOIP2020 字符串匹配
    UOJ-618 JOISC2021 聚会 2
    Codeforces Round #740 (Div. 1, based on VK Cup 2021
    PipeCAD
    第三次全国国土调查相关信息记录
    统计研究区内Landsat影像数量
    GEE数据导出注意事项
  • 原文地址:https://www.cnblogs.com/lidongaistudy/p/9619534.html
Copyright © 2011-2022 走看看