• python+selenium自动化(六)之元素其他属性定位


    1、通过name属性定位   find_element_by_name 

    百度首页举例子

    from selenium import webdriver
    import time
    driver = webdriver.Chrome()
    driver.get(url="http://www.baidu.com")
    driver.maximize_window()
    driver.find_element_by_name("wd").send_keys("hello world")
    time.sleep(3)
    driver.quit()

    2、通过class属性定位   find_element_by_class_name

     

    from selenium import webdriver
    import time
    driver = webdriver.Chrome()
    driver.get(url="http://www.baidu.com")
    driver.maximize_window()
    # driver.find_element_by_name("wd").send_keys("hello world")
    driver.find_element_by_class_name("s_ipt").send_keys("hello world")
    time.sleep(3)
    driver.quit()

    3、通过标签tag_name属性定位   find_element_by_tag_name   (不建议用,因为页面标签很多)

     

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
        <input type="text" id="test">
    </body>
    </html>
    from selenium import webdriver
    import time
    driver = webdriver.Chrome()
    # driver.get(url="http://www.baidu.com")
    driver.get("file://D:/python+selenium/test/tag_name.html")   # html文件的绝对路径
    driver.maximize_window()
    driver.find_element_by_tag_name("input").send_keys("hello world")
    time.sleep(3)
    driver.quit()

    4、通过超链接文本定位   find_element_by_link_text

     

    from selenium import webdriver
    import time
    driver = webdriver.Chrome()
    # driver.get(url="http://www.baidu.com")
    driver.get("file://D:/python+selenium/test/tag_name.html")   # html文件的绝对路径
    driver.maximize_window()
    driver.find_element_by_link_text("百度一下").click()
    time.sleep(3)
    driver.quit()
    <a href="http://www.baidu.com">百度一下</a>  可以看到这个元素a,超链接href="http://www.baidu.com",点击百度一下这个文本,会自动跳转到百度首页,这个方法针对有超链接跳转的文本

     5、通过超链接,文本模糊匹配定位   find_element_by_partial_link_text

     这个方法是,超链接的文本过长,通过部分文本模糊匹配

    from selenium import webdriver
    import time
    driver = webdriver.Chrome()
    # driver.get(url="http://www.baidu.com")
    driver.get("file://D:/python+selenium/test/tag_name.html")   # html文件的绝对路径
    driver.maximize_window()
    # driver.find_element_by_link_text("百度一下").click()
    driver.find_element_by_partial_link_text("百度").click()
    time.sleep(3)
    driver.quit()

    6、通过css定位   find_element_by_css_selector  

    from selenium import webdriver
    import time
    driver = webdriver.Chrome()
    driver.get(url="http://www.baidu.com")
    driver.maximize_window()
    driver.find_element_by_css_selector("[id = 'kw']").send_keys("hello world") 
    time.sleep(3)
    driver.quit()

    当然,通过css定位肯定不止这一种,还有很多其他的方式,可以参考博客: https://www.cnblogs.com/zuodaozhudemeng/p/7487798.html

    7、通过xpath定位   find_element_by_xpath 

    from selenium import webdriver
    import time
    driver = webdriver.Chrome()
    driver.get(url="http://www.baidu.com")
    driver.maximize_window()
    driver.find_element_by_xpath("//input[@id = 'kw']").send_keys("hello world")
    time.sleep(3)
    driver.quit()

    通过 xpath 的多种定位方法,会写一篇详细的博客来解释,个人而言,用的比较多的还是xpath方法来定位 。

    以上就是元素定位的常用方法,根据实际情况去具体应用。

  • 相关阅读:
    iOS NSString中的搜索方法rangeOfString
    iOS 远程推送通知
    iOS PushMeBaby日志提示SSLwrite():-36 94
    iOS [[NSBundle mainBundle] pathForResource:@"" ofType:@""]无法获取到文件
    iOS 申请测试用的远程推送证书
    数据结构与算法学习笔记(五)
    iOS 上传新版本到AppStore时报错ITMS-90034
    数据结构与算法学习笔记(四)
    数据结构与算法学习笔记(三)
    iOS开发日记49-详解定位CLLocation
  • 原文地址:https://www.cnblogs.com/jinbaobao/p/13931367.html
Copyright © 2020-2023  润新知