博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[python爬虫] Selenium常见元素定位方法和操作的学习介绍
阅读量:4987 次
发布时间:2019-06-12

本文共 6047 字,大约阅读时间需要 20 分钟。

        这篇文章主要Selenium+Python自动测试或爬虫中的常见定位方法、鼠标操作、键盘操作介绍,希望该篇基础性文章对你有所帮助,如果有错误或不足之处,请海涵~同时CSDN总是屏蔽这篇文章,再加上最近只能专家和伯乐发表文章至首页(why),这严重影响别人阅读新人的文章和程序猿的激情,所以想起自己博客园的账号,感觉编辑功能非常不错啊,以后两边都会更新文章。最后记录此站第一篇文章,希望能分享更多文章于此!

        前文目录:
        
        
        
        
        

一.定位元素方法

        官网地址:

        这里有各种策略用于定位网页中的元素(locate elements),你可以选择最适合的方案,Selenium提供了一下方法来定义一个页面中的元素:

find_element_by_idfind_element_by_namefind_element_by_xpathfind_element_by_link_textfind_element_by_partial_link_textfind_element_by_tag_namefind_element_by_class_namefind_element_by_css_selector

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

find_elements_by_namefind_elements_by_xpathfind_elements_by_link_textfind_elements_by_partial_link_textfind_elements_by_tag_namefind_elements_by_class_namefind_elements_by_css_selector

        除了上面给出的公共方法,这里也有两个在页面对象定位器有用的私有方法。这两个私有方法是find_element和find_elements。

        常用方法是通过xpath相对路径进行定位,同时CSS也是比较好的方法。举例:

   

        定位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 emaildriver = webdriver.Firefox()  driver.get("http://mail.163.com/")elem_user = driver.find_element_by_name("username")elem_user.clearelem_user.send_keys("15201615157")  elem_pwd = driver.find_element_by_name("password")elem_pwd.clearelem_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 获取当前页面的URLis_displayed() 设置该元素是否可见is_enabled() 判断元素是否被使用is_selected() 判断元素是否被选中tag_name 返回元素的tagName

        举例代码如下:

from selenium import webdriver  from selenium.webdriver.common.keys import Keys  import timedriver = webdriver.PhantomJS(executable_path="G:\phantomjs-1.9.1-windows\phantomjs.exe")   driver.get("http://www.baidu.com/")size = driver.find_element_by_name("wd").sizeprint size#尺寸: {'width': 500, 'height': 22}news = driver.find_element_by_xpath("//div[@id='u1']/a[1]").textprint 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_trhao123location = driver.find_element_by_xpath("//div[@id='u1']/a[3]").locationprint 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 timefrom selenium import webdriverfrom selenium.webdriver.common.keys import Keysfrom selenium.webdriver.common.action_chains import ActionChainsdriver = 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()

        效果如下图所示,通过xpath定位到图片位置并右击鼠标,在弹出的菜单中选择“另存为图片”。但是如何点击“另存为对话框”的“保存”按钮是个难点,目前刚学习阶段,境界没到无法解决。原因:

        WebDriver cannot directly interact with dialog windows this is because dialog windows are the domain of the operating system and not the webpage.

        该部分推荐参考资料:
       
       
       
        书籍《selenium2 python自动化测试》 作者:虫师

五.键盘操作

        参考:

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

send_keys(Keys.ENTER) 按下回车键send_keys(Keys.TAB) 按下Tab制表键send_keys(Keys.SPACE) 按下空格键spacesend_keys(Kyes.ESCAPE) 按下回退键Escsend_keys(Keys.BACK_SPACE) 按下删除键BackSpacesend_keys(Keys.SHIFT) 按下shift键send_keys(Keys.CONTROL) 按下Ctrl键send_keys(Keys.ARROW_DOWN) 按下鼠标光标向下按键send_keys(Keys.CONTROL,'a') 组合键全选Ctrl+Asend_keys(Keys.CONTROL,'c') 组合键复制Ctrl+Csend_keys(Keys.CONTROL,'x') 组合键剪切Ctrl+Xsend_keys(Keys.CONTROL,'v') 组合键粘贴Ctrl+V

        这里使用的例子参考虫师的书籍《selenium2 python自动化测试》,推荐该书给大家。代码还是非常有意思的,大家自己去感受下吧~

#coding=utf-8import timefrom selenium import webdriverfrom selenium.webdriver.common.keys import Keysdriver = 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()

        等会晚上7点有个360的笔试,好好准备下吧!最后希望文章对你有所帮助吧,如果有错误或不足之处,还请海涵~同时接下来学习下Linux和下面作者的文章。

        
      (By:Eastmount 2015-9-15 下午5点   

 

转载于:https://www.cnblogs.com/eastmount/p/4810690.html

你可能感兴趣的文章
snprintf 返回值陷阱 重新封装
查看>>
asp.net GridView多行表头的实现,合并表头
查看>>
C#套打
查看>>
PolyCluster: Minimum Fragment Disagreement Clustering for Polyploid Phasing 多聚类:用于多倍体的最小碎片不一致聚类...
查看>>
【每日进步】July 2012
查看>>
327 作业
查看>>
sql 取汉字首字母
查看>>
javascript 封装ajax(多版本)
查看>>
bzoj4034: [HAOI2015]树上操作(树剖)
查看>>
android-Activity
查看>>
${sessionScope.user}的使用方法
查看>>
IOS断点下载
查看>>
Steal 偷天换日 题解(From luoguBlog)
查看>>
Hadoop HDFS学习总结
查看>>
C#wxpay和alipay
查看>>
Combination Sum
查看>>
WCF开发框架形成之旅---结合代码生成工具实现快速开发
查看>>
Spring事务管理
查看>>
JS||JQUERY常用语法
查看>>
talend hive数据导入到mysql中
查看>>