zoukankan      html  css  js  c++  java
  • Selenium常见元素定位方法和操作

    一. 定位元素方法


            官网地址:http://selenium-python.readthedocs.org/locating-elements.html
            这里有各种策略用于定位网页中的元素(locate elements),你可以选择最适合的方案,Selenium提供了一下方法来定义一个页面中的元素:

    • find_element_by_id
    • find_element_by_name
    • find_element_by_xpath
    • find_element_by_link_text
    • find_element_by_partial_link_text
    • find_element_by_tag_name
    • find_element_by_class_name
    • find_element_by_css_selector

            下面是查找多个元素(这些方法将返回一个列表):

    • find_elements_by_name
    • find_elements_by_xpath
    • find_elements_by_link_text
    • find_elements_by_partial_link_text
    • find_elements_by_tag_name
    • find_elements_by_class_name
    • find_elements_by_css_selector

            除了上面给出的公共方法,这里也有两个在页面对象定位器有用的私有方法。这两个私有方法是find_element和find_elements。
            常用方法是通过xpath相对路径进行定位,同时CSS也是比较好的方法。举例

    <html>  
     <body>  
      <form id="loginForm">  
       <input name="username" type="text" />  
       <input name="password" type="password" />  
       <input name="continue" type="submit" value="Login" />  
       <input name="continue" type="button" value="Clear" />  
      </form>  
    </body>  
    <html>  
    

      定位username元素的方法如下:

    username = driver.find_element_by_xpath("//form[input/@name='username']")  
    username = driver.find_element_by_xpath("//form[@id='loginForm']/input[1]")  
    username = driver.find_element_by_xpath("//input[@name='username']") 
    

       [1] 第一个form元素通过一个input子元素,name属性和值为username实现
           [2] 通过id=loginForm值的form元素找到第一个input子元素
           [3] 属性名为name且值为username的第一个input元素

    二. 操作元素方法

            在讲述完定位对象(locate elements)之后我们需要对该已定位对象进行操作,通常所有的操作与页面交互都将通过WebElement接口,常见的操作元素方法如下:

    • clear 清除元素的内容
    • send_keys 模拟按键输入
    • click 点击元素
    • submit 提交表单

            举例自动访问FireFox浏览器自动登录163邮箱。

    from selenium import webdriver    
    from selenium.webdriver.common.keys import Keys    
    import time  
      
    # Login 163 email  
    driver = webdriver.Firefox()    
    driver.get("http://mail.163.com/")  
      
    elem_user = driver.find_element_by_name("username")  
    elem_user.clear  
    elem_user.send_keys("15201615157")    
    elem_pwd = driver.find_element_by_name("password")  
    elem_pwd.clear  
    elem_pwd.send_keys("******")    
    elem_pwd.send_keys(Keys.RETURN)  
    #driver.find_element_by_id("loginBtn").click()  
    #driver.find_element_by_id("loginBtn").submit()  
    time.sleep(5)    
    assert "baidu" in driver.title    
    driver.close()    
    driver.quit()    
    

      首先通过name定位用户名和密码,再调用方法clear()清除输入框默认内容,如“请输入密码”等提示,通过send_keys("**")输入正确的用户名和密码,最后通过click()点击登录按钮或send_keys(Keys.RETURN)相当于回车登录,submit()提交表单。
            PS:如果需要输入中文,防止编码错误使用send_keys(u"中文用户名")。

    三. WebElement接口获取值

            通过WebElement接口可以获取常用的值,这些值同样非常重要。

    • size 获取元素的尺寸
    • text 获取元素的文本
    • get_attribute(name) 获取属性值
    • location 获取元素坐标,先找到要获取的元素,再调用该方法
    • page_source 返回页面源码
    • driver.title 返回页面标题
    • current_url 获取当前页面的URL
    • is_displayed() 设置该元素是否可见
    • is_enabled() 判断元素是否被使用
    • is_selected() 判断元素是否被选中
    • tag_name 返回元素的tagName

            举例代码如下:

    from selenium import webdriver    
    from selenium.webdriver.common.keys import Keys    
    import time  
      
    driver = webdriver.PhantomJS(executable_path="G:phantomjs-1.9.1-windowsphantomjs.exe")     
    driver.get("http://www.baidu.com/")  
      
    size = driver.find_element_by_name("wd").size  
    print size  
    #尺寸: {'width': 500, 'height': 22}  
      
    news = driver.find_element_by_xpath("//div[@id='u1']/a[1]").text  
    print news  
    #文本: 新闻  
      
    href = driver.find_element_by_xpath("//div[@id='u1']/a[2]").get_attribute('href')  
    name = driver.find_element_by_xpath("//div[@id='u1']/a[2]").get_attribute('name')  
    print href,name  
    #属性值: http://www.hao123.com/ tj_trhao123  
      
    location = driver.find_element_by_xpath("//div[@id='u1']/a[3]").location  
    print location  
    #坐标: {'y': 19, 'x': 498}  
      
    print driver.current_url  
    #当前链接: https://www.baidu.com/  
    print driver.title  
    #标题: 百度一下, 你就知道  
      
    result = location = driver.find_element_by_id("su").is_displayed()  
    print result  
    #是否可见: True  
    

      

    四. 鼠标操作

            在现实的自动化测试中关于鼠标的操作不仅仅是click()单击操作,还有很多包含在ActionChains类中的操作。如下:

    • context_click(elem) 右击鼠标点击元素elem,另存为等行为
    • double_click(elem) 双击鼠标点击元素elem,地图web可实现放大功能
    • drag_and_drop(source,target) 拖动鼠标,源元素按下左键移动至目标元素释放
    • move_to_element(elem) 鼠标移动到一个元素上
    • click_and_hold(elem) 按下鼠标左键在一个元素上
    • perform() 在通过调用该函数执行ActionChains中存储行为

            举例如下图所示,获取通过鼠标右键另存为百度图片logo。代码:

    import time  
    from selenium import webdriver  
    from selenium.webdriver.common.keys import Keys  
    from selenium.webdriver.common.action_chains import ActionChains  
      
    driver = webdriver.Firefox()  
    driver.get("http://www.baidu.com")  
      
    #鼠标移动至图片上 右键保存图片  
    elem_pic = driver.find_element_by_xpath("//div[@id='lg']/img")  
    print elem_pic.get_attribute("src")  
    action = ActionChains(driver).move_to_element(elem_pic)  
    action.context_click(elem_pic)  
      
    #重点:当右键鼠标点击键盘光标向下则移动至右键菜单第一个选项  
    action.send_keys(Keys.ARROW_DOWN)  
    time.sleep(3)  
    action.send_keys('v') #另存为  
    action.perform()  
      
    #获取另存为对话框(失败)  
    alert.switch_to_alert()  
    alert.accept()  
    

      

    五. 键盘操作

            参考:http://selenium-python.readthedocs.org/api.html
            前面讲述了鼠标操作,现在讲述键盘操作。在webdriver的Keys类中提供了键盘所有的按键操作,当然也包括一些常见的组合键操作如Ctrl+A(全选)、Ctrl+C(复制)、Ctrl+V(粘贴)。更多键参考官方文档对应的编码。

      • send_keys(Keys.ENTER) 按下回车键

      • send_keys(Keys.TAB) 按下Tab制表键

      • send_keys(Keys.SPACE) 按下空格键space

      • send_keys(Kyes.ESCAPE) 按下回退键Esc

      • send_keys(Keys.BACK_SPACE) 按下删除键BackSpace

      • send_keys(Keys.SHIFT) 按下shift键

      • send_keys(Keys.CONTROL) 按下Ctrl键

      • send_keys(Keys.ARROW_DOWN) 按下鼠标光标向下按键

      • send_keys(Keys.CONTROL,'a') 组合键全选Ctrl+A

      • send_keys(Keys.CONTROL,'c') 组合键复制Ctrl+C

      • send_keys(Keys.CONTROL,'x') 组合键剪切Ctrl+X

      • send_keys(Keys.CONTROL,'v') 组合键粘贴Ctrl+V

      • #coding=utf-8  
        import time  
        from selenium import webdriver  
        from selenium.webdriver.common.keys import Keys  
          
        driver = webdriver.Firefox()  
        driver.get("http://www.baidu.com")  
          
        #输入框输入内容  
        elem = driver.find_element_by_id("kw")  
        elem.send_keys("Eastmount CSDN")  
        time.sleep(3)  
          
        #删除一个字符CSDN 回退键  
        elem.send_keys(Keys.BACK_SPACE)  
        elem.send_keys(Keys.BACK_SPACE)  
        elem.send_keys(Keys.BACK_SPACE)  
        elem.send_keys(Keys.BACK_SPACE)  
        time.sleep(3)  
          
        #输入空格+"博客"  
        elem.send_keys(Keys.SPACE)  
        elem.send_keys(u"博客")  
        time.sleep(3)  
          
        #ctrl+a 全选输入框内容  
        elem.send_keys(Keys.CONTROL,'a')  
        time.sleep(3)  
          
        #ctrl+x 剪切输入框内容  
        elem.send_keys(Keys.CONTROL,'x')  
        time.sleep(3)  
          
        #输入框重新输入搜索  
        elem.send_keys(Keys.CONTROL,'v')  
        time.sleep(3)  
          
        #通过回车键替代点击操作  
        driver.find_element_by_id("su").send_keys(Keys.ENTER)  
        time.sleep(3)  
          
        driver.quit()  
        

          

  • 相关阅读:
    【前端】常用总结(二)
    【Golang】爬虫笔记
    ubuntu16.04安装SSH服务
    windows下配置pytorch环境
    使用VNC连接ubuntu16.4错误Authentication Failure问题
    window使用VNC远程ubuntu16.04
    ubuntu16.04安装nvidia显卡驱动
    python批量读取并显示图片,处理异常。
    将nii文件CT图像更改窗宽窗位之后保存成nii文件
    yaml.load与yaml.dump的用法
  • 原文地址:https://www.cnblogs.com/zhaobang/p/7541343.html
Copyright © 2011-2022 走看看