基于python的selenium常用操作方法(1)
1 selenium定位方法???
Selenium提供了8种定位方式。 ·?????????id ·?????????name ·?????????class name ·?????????tag name ·?????????link text ·?????????partial link text ·?????????xpath ·?????????css selector 这8种定位方式在Python selenium中所对应的方法为: ·?????????find_element_by_id() ·?????????find_element_by_name() ·?????????find_element_by_class_name() ·?????????find_element_by_tag_name() ·?????????find_element_by_link_text() ·?????????find_element_by_partial_link_text() ·?????????find_element_by_xpath() ·?????????find_element_by_css_selector() 定位方法的用法 假如我们有一个Web页面,通过前端工具(如,Firebug)查看到一个元素的属性是这样的。 <html> 我们的目的是要定位input标签的输入框。 ·?????????通过id定位: ·?????????通过name定位: ·?????????通过class name定位: ·?????????通过tag name定位: ·?????????通过xpath定位,xpath定位有N种写法,这里列几个常用写法: ·?????????通过css定位,css定位有N种写法,这里列几个常用写法: 接下来,我们的页面上有一组文本链接。 <a?class="mnav"?href="http://news.baidu.com"?name="tj_trnews">新闻</a> ·?????????通过link text定位: dr.find_element_by_partial_link_text("新") ? 2 控制浏览器操作 ?? 控制浏览器窗口大小 有时候我们希望能以某种浏览器尺寸打开,让访问的页面在这种尺寸下运行。例如可以将浏览器设置成移动端大小(480* 800),然后访问移动站点,对其样式进行评估;WebDriver提供了set_window_size()方法来设置浏览器的大小。 from?selenium?import?webdriver driver = webdriver.Firefox() #?参数数字为像素点 在PC端执行自动化测试脚本大多的情况下是希望浏览器在全屏幕模式下执行,那么可以使用maximize_window()方法使打开的浏览器全屏显示,其用法与set_window_size()?相同,但它不需要参数。 控制浏览器后退、前进 在使用浏览器浏览网页时,浏览器提供了后退和前进按钮,可以方便地在浏览过的网页之间切换,WebDriver也提供了对应的back()和forward()方法来模拟后退和前进按钮。下面通过例子来演示这两个方法的使用。 from selenium import webdriver driver = webdriver.Firefox() #访问百度首页 #访问新闻页面 #返回(后退)到百度首页 #前进到新闻页 为了看清脚本的执行过程,下面每操作一步都通过print()来打印当前的URL地址。 刷新页面 有时候需要手动刷新(F5) 页面。 …… 3 WebDriver常用方法 ?? 点击和输入 前面我们已经学习了定位元素, 定位只是第一步, 定位之后需要对这个元素进行操作, 或单击(按钮) 或输入(输入框) , 下面就来认识?WebDriver?中最常用的几个方法: ·?????????clear(): 清除文本。 ·?????????send_keys (value): 模拟按键输入。 ·?????????click(): 单击元素。 driver = webdriver.Chrome() driver.find_element_by_id("kw").clear() ?提交 ·?????????submit() submit()方法用于提交表单。 例如, 在搜索框输入关键字之后的“回车” 操作, 就可以通过该方法模拟。 search_text = driver.find_element_by_id(‘kw‘) 有时候?submit()可以与?click()方法互换来使用,?submit()同样可以提交一个按钮, 但?submit()的应用范围远不及?click()广泛。 其他常用方法 ·?????????size: 返回元素的尺寸。 ·?????????text: 获取元素的文本。 ·?????????get_attribute(name): 获得属性值。 ·?????????is_displayed(): 设置该元素是否用户可见。 driver.get("http://www.baidu.com") #?获得输入框的尺寸 #?返回百度页面底部备案信息 #?返回元素的属性值, 可以是?id、?name、?type?或其他任意属性 #?返回元素的结果是否可见, 返回结果为?True?或?False 输出结果: {‘width‘:?500,?‘height‘:?22} 执行上面的程序并查看结果:?size?方法用于获取百度输入框的宽、 高,?text?方法用于获得百度底部的备案信息,get_attribute()用于获得百度输入的?type?属性的值,?is_displayed()用于返回一个元素是否可见, 如果可见则返回True, 否则返回?False。 4 鼠标事件 ?? 在?WebDriver?中, 将这些关于鼠标操作的方法封装在?ActionChains?类提供。 ActionChains?类提供了鼠标操作的常用方法: ·?????????perform(): 执行所有?ActionChains?中存储的行为; ·?????????context_click(): 右击; ·?????????double_click(): 双击; ·?????????drag_and_drop(): 拖动; ·?????????move_to_element(): 鼠标悬停。? 鼠标悬停操作 from?selenium?import?webdriver driver.get("https://www.baidu.cn") #?定位到要悬停的元素 ·?????????from selenium.webdriver import ActionChains 导入提供鼠标操作的?ActionChains?类。 ·?????????ActionChains(driver) 调用?ActionChains()类, 将浏览器驱动?driver?作为参数传入。 ·?????????move_to_element(above) context_click()方法用于模拟鼠标右键操作, 在调用时需要指定元素定位。 ·?????????perform() 执行所有?ActionChains?中存储的行为, 可以理解成是对整个操作的提交动作。 5 键盘事件 ?? Keys()类提供了键盘上几乎所有按键的方法。 前面了解到,?send_keys()方法可以用来模拟键盘输入, 除此 之外, 我们还可以用它来输入键盘上的按键, 甚至是组合键, 如?Ctrl+A、?Ctrl+C?等。 #?引入?Keys?模块 #?输入框输入内容 #?删除多输入的一个?m #?输入空格键+“教程” # ctrl+a?全选输入框内容 # ctrl+x?剪切输入框内容 ·?????????from selenium.webdriver.common.keys import Keys 在使用键盘按键方法前需要先导入?keys?类。 以下为常用的键盘操作: ·?????????send_keys(Keys.BACK_SPACE)?删除键(BackSpace) ·?????????send_keys(Keys.SPACE)?空格键(Space) ·?????????send_keys(Keys.TAB)?制表键(Tab) ·?????????send_keys(Keys.ESCAPE)?回退键(Esc) ·?????????send_keys(Keys.ENTER)?回车键(Enter) ·?????????send_keys(Keys.CONTROL,‘a’)?全选(Ctrl+A)
·?????????send_keys(Keys.F1)?键盘?F1 ·?????????…… ·?????????send_keys(Keys.F12)?键盘?F12 6 获取断言信息 ?? 不管是在做功能测试还是自动化测试,最后一步需要拿实际结果与预期进行比较。这个比较的称之为断言。 我们通常可以通过获取title?、URL和text等信息进行断言。text方法在前面已经讲过,它用于获取标签对之间的文本信息。 下面同样以百度为例,介绍如何获取这些信息。 from?time?import?sleep print(‘Before search================‘) #?打印当前页面title #?打印当前页面URL driver.find_element_by_id("su").click() print(‘After search================‘) #?再次打印当前页面title 脚本运行结果如下: Before?search================ ·?????????title:用于获得当前页面的标题。 ·?????????current_url:用户获得当前页面的URL。 ·?????????text:获取搜索条目的文本信息。 ?7 设置元素等待 ?? WebDriver提供了两种类型的等待:显式等待和隐式等待。 显式等待 显式等待使WebdDriver等待某个条件成立时继续执行,否则在达到最大时长时抛出超时异常(TimeoutException)。 from?selenium.webdriver.common.by?import?By element = WebDriverWait(driver,?5,?0.5).until( WebDriverWait(driver,timeout,poll_frequency=0.5,ignored_exceptions=None) ·?????????driver?:浏览器驱动。 ·?????????timeout?:最长超时时间,默认以秒为单位。 ·?????????poll_frequency?:检测的间隔(步长)时间,默认为0.5S。 ·?????????ignored_exceptions?:超时后的异常信息,默认情况下抛NoSuchElementException异常。 WebDriverWait()一般由until()或until_not()方法配合使用,下面是until()和until_not()方法的说明。?* until(method,message=‘’)?调用该方法提供的驱动程序作为一个参数,直到返回值为True。?* until_not(method,message=‘’)调用该方法提供的驱动程序作为一个参数,直到返回值为False。 在本例中,通过as关键字将expected_conditions?重命名为EC,并调用presence_of_element_located()方法判断元素是否存在。 隐式等待 WebDriver提供了implicitly_wait()方法来实现隐式等待,默认设置为0。它的用法相对来说要简单得多。 from?selenium.common.exceptions?import?NoSuchElementException #?设置隐式等待为10秒 implicitly_wait()默认参数的单位为秒,本例中设置等待时长为10秒。首先这10秒并非一个固定的等待时间,它并不影响脚本的执行速度。其次,它并不针对页面上的某一元素进行等待。当脚本执行到某个元素定位时,如果元素可以定位,则继续执行;如果元素定位不到,则它将以轮询的方式不断地判断元素是否被定位到。假设在第6秒定位到了元素则继续执行,若直到超出设置时长(10秒)还没有定位到元素,则抛出异常。 8 定位一组元素 ?? WebDriver还提供了8种用于定位一组元素的方法。 find_elements_by_id() 定位一组元素的方法与定位单个元素的方法类似,唯一的区别是在单词element后面多了一个s表示复数。 接下来通过例子演示定位一组元素的使用: #?定位一组元素 #?循环遍历出每一条搜索结果的标题 程序运行结果: Selenium?- Web Browser Automation 9 多表单切换 ?? 在Web应用中经常会遇到frame/iframe表单嵌套页面的应用,WebDriver只能在一个页面上对元素识别与定位,对于frame/iframe表单内嵌页面上的元素无法直接定位。这时就需要通过switch_to.frame()方法将当前定位的主体切换为frame/iframe表单的内嵌页面中。 ??<body> 126邮箱登录框的结构大概是这样子的,想要操作登录框必须要先切换到iframe表单。 driver.get("http://www.126.com") driver.switch_to.frame(‘x-URS-iframe‘) switch_to.frame()?默认可以直接取表单的id?或name属性。如果iframe没有可用的id和name属性,则可以通过下面的方式进行定位。 #先通过xpth定位到iframe #再将定位对象传给switch_to.frame()方法 除此之外,在进入多级表单的情况下,还可以通过switch_to.default_content()跳回最外层的页面。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |