‘壹’ python selenium怎么定位图中这种下拉框的选项
xpath 试试这个 //div[class='ant-time-picker-panel-select']/ul//li
‘贰’ Robotframework RIDE+Selenium2Library 怎么选下拉菜单里的值
我用的比较笨的办法,先点击那个输入框,然后等待列表出现之后,点击列表中的元素。
我测试的下拉列表是这样子的:
如果你的下拉列表是select类型的,可以用selenium2Library中的select form list by value
‘叁’ 如何在python中使用selenium
下载python版本的python包,放入到python的lib下面,然后下载selenium的jar。
启动使用java -jar selenium-server-standalone-2.0b3.jar
测试例子:
from selenium import webdriver
from selenium.common.exceptions import NoSuchElementException
from selenium.webdriver.common.keys import Keys
import time
browser = webdriver.Firefox() # Get local session of firefox
browser.get("") # Load page
assert "Yahoo!" in browser.title
elem = browser.find_element_by_name("p") # Find the query box
elem.send_keys("seleniumhq" + Keys.RETURN)
time.sleep(0.2) # Let the page load, will be added to the API
try:
browser.find_element_by_xpath("//a[contains(@href,'')]")
except NoSuchElementException:
assert 0, "can't find seleniumhq"
browser.close()
运行的结果是打开雅虎浏览器搜素seleniuhq,然后查找
Selenium (SeleniumHQ) 是 thoughtworks公司的一个集成测试的强大工具。
一、Selenium 的版本
Selenium 现在存在2个版本,一个叫 selenium-core, 一个叫selenium-rc 。
selenium-core 是使用HTML的方式来编写测试脚本,你也可以使用 Selenium-IDE来录制脚本,但是目前Selenium-IDE只有 FireFox 版本。
Selenium-RC 是 selenium-remote control 缩写,是使用具体的语言来编写测试类。
selenium-rc 支持的语言非常多,这里我们着重关注java的方式。这里讲的也主要是 selenium-rc,因为个人还是喜欢这种方式.
下图是Selenium IDE的运行界面截图:
‘肆’ python+selenium自动化测试定位下拉菜单并点击
那就改用点击来解决.
先点击倒三角按钮, 然后点击option value="132"
另外select标签怎么有个editable=false ?
‘伍’ python+selenium怎么定位页面弹窗的元素
1、问题发生描述:
从一个页面进行点击等操作,页面跳转到第二个页面,对第二个页面中的元素,采取任何措施定位都报错,问题报错点如下:
2、出现问题的原因:
窗口句柄还停留在上一个页面,对于当前新弹出的页面还没有定位,因此新页面的任何元素都定位不到
3、解决方案:
在新页面操作元素之前,需添加句柄操作,方式如下:
1、使用driver.current_window_handle#获取当前窗口句柄,添加此方法,仍报相同的错误,因此不能采用这种方式进行解决问题
2、使用driver.switch_to_window(driver.window_handles[1]),或者 driver.switch_to_window(self.driver.window_handles[-1]) ,两种方式中任选一种即可找到对应的元素
添加后的代码如下:
每天记录进步一点点.........
‘陆’ python selenium drag_and_drop()和drag_and_drop_with_offset()怎么使用
用selenium做自动化,有时候会遇到需要模拟鼠标操作才能进行的情况,比如单击、双击、点击鼠标右键、拖拽等等。而selenium给我们提供了一个类来处理这类事件——ActionChains
selenium.webdriver.common.action_chains.ActionChains(driver)
这个类基本能够满足我们所有对鼠标操作的需求。
1.ActionChains基本用法
首先需要了解ActionChains的执行原理,当你调用ActionChains的方法时,不会立即执行,而是会将所有的操作按顺序存放在一个队列里,当你调用perform()方法时,队列中的时间会依次执行。
这种情况下我们可以有两种调用方法:
链式写法
menu = driver.find_element_by_css_selector(".nav")
hidden_submenu = driver.find_element_by_css_selector(".nav #submenu1")
ActionChains(driver).move_to_element(menu).click(hidden_submenu).perform()
1
2
3
4
分步写法
menu = driver.find_element_by_css_selector(".nav")
hidden_submenu = driver.find_element_by_css_selector(".nav #submenu1")
actions = ActionChains(driver)
actions.move_to_element(menu)
actions.click(hidden_submenu)
actions.perform()
1
2
3
4
5
6
7
两种写法本质是一样的,ActionChains都会按照顺序执行所有的操作。
2.ActionChains方法列表
click(on_element=None) ——单击鼠标左键
click_and_hold(on_element=None) ——点击鼠标左键,不松开
context_click(on_element=None) ——点击鼠标右键
double_click(on_element=None) ——双击鼠标左键
drag_and_drop(source, target) ——拖拽到某个元素然后松开
drag_and_drop_by_offset(source, xoffset, yoffset) ——拖拽到某个坐标然后松开
key_down(value, element=None) ——按下某个键盘上的键
key_up(value, element=None) ——松开某个键
move_by_offset(xoffset, yoffset) ——鼠标从当前位置移动到某个坐标
move_to_element(to_element) ——鼠标移动到某个元素
move_to_element_with_offset(to_element, xoffset, yoffset) ——移动到距某个元素(左上角坐标)多少距离的位置
perform() ——执行链中的所有动作
release(on_element=None) ——在某个元素位置松开鼠标左键
send_keys(*keys_to_send) ——发送某个键到当前焦点的元素
send_keys_to_element(element, *keys_to_send) ——发送某个键到指定元素
接下来用示例来详细说明和演示每一个方法的用法:
3.代码示例
1. 点击操作
代码:
- # -*- coding: utf-8 -*-from selenium import webdriverfrom selenium.webdriver.common.action_chains import ActionChainsfrom time import sleep
- driver = webdriver.Firefox()
- driver.implicitly_wait(10)
- driver.maximize_window()
- driver.get('')
- click_btn = driver.find_element_by_xpath('//input[@value="click me"]') # 单击按钮doubleclick_btn = driver.find_element_by_xpath('//input[@value="dbl click me"]') # 双击按钮rightclick_btn = driver.find_element_by_xpath('//input[@value="right click me"]') # 右键单击按钮ActionChains(driver).click(click_btn).double_click(doubleclick_btn).context_click(rightclick_btn).perform() # 链式用法print driver.find_element_by_name('t2').get_attribute('value')
- sleep(2)
- driver.quit()
结果:
- [CLICK][DOUBLE_CLICK][RIGHT_CLICK]1
2.鼠标移动
示例代码:
- # -*- coding: utf-8 -*-from selenium import webdriverfrom selenium.webdriver.common.action_chains import ActionChainsfrom time import sleep
- driver = webdriver.Firefox()
- driver.implicitly_wait(10)
- driver.maximize_window()
- driver.get('')
- write = driver.find_element_by_xpath('//input[@value="Write on hover"]') # 鼠标移动到此元素,在下面的input框中会显示“Mouse moved”blank = driver.find_element_by_xpath('//input[@value="Blank on hover"]') # 鼠标移动到此元素,会清空下面input框中的内容result = driver.find_element_by_name('t1')
- action = ActionChains(driver)
- action.move_to_element(write).perform() # 移动到write,显示“Mouse moved”print result.get_attribute('value')# action.move_to_element(blank).perform()action.move_by_offset(10, 50).perform() # 移动到距离当前位置(10,50)的点,与上句效果相同,移动到blank上,清空print result.get_attribute('value')
- action.move_to_element_with_offset(blank, 10, -40).perform() # 移动到距离blank元素(10,-40)的点,可移动到write上print result.get_attribute('value')
- sleep(2)
- driver.quit()242526272829
结果
- Mouse moved
- Mouse moved123
一般很少用位置关系来移动鼠标,如果需要,可参考下面的链接来测量元素位置
3.拖拽
代码:
- # -*- coding: utf-8 -*-from selenium import webdriverfrom selenium.webdriver.common.action_chains import ActionChainsfrom time import sleep
- driver = webdriver.Firefox()
- driver.implicitly_wait(10)
- driver.maximize_window()
- driver.get('ls.htm')
- dragger = driver.find_element_by_id('dragger') # 被拖拽元素item1 = driver.find_element_by_xpath('//div[text()="Item 1"]') # 目标元素1item2 = driver.find_element_by_xpath('//div[text()="Item 2"]') # 目标2item3 = driver.find_element_by_xpath('//div[text()="Item 3"]') # 目标3item4 = driver.find_element_by_xpath('//div[text()="Item 4"]') # 目标4action = ActionChains(driver)
- action.drag_and_drop(dragger, item1).perform() # 1.移动dragger到目标1sleep(2)
- action.click_and_hold(dragger).release(item2).perform() # 2.效果与上句相同,也能起到移动效果sleep(2)
- action.click_and_hold(dragger).move_to_element(item3).release().perform() # 3.效果与上两句相同,也能起到移动的效果sleep(2)# action.drag_and_drop_by_offset(dragger, 400, 150).perform() # 4.移动到指定坐标action.click_and_hold(dragger).move_by_offset(400, 150).release().perform() # 5.与上一句相同,移动到指定坐标sleep(2)
- driver.quit()2425262728
结果:
- dropped dropped dropped dropped1
一般用坐标定位很少,用上例中的方法1足够了,如果看源码,会发现方法2其实就是方法1中的drag_and_drop()的实现。注意:拖拽使用时注意加等待时间,有时会因为速度太快而失败。
4.按键
模拟按键有多种方法,能用win32api来实现,能用SendKeys来实现,也可以用selenium的WebElement对象的send_keys()方法来实现,这里ActionChains类也提供了几个模拟按键的方法。
代码1:
- # -*- coding: utf-8 -*-from selenium import webdriverfrom selenium.webdriver.common.action_chains import ActionChainsfrom time import sleep
- driver = webdriver.Firefox()
- driver.implicitly_wait(10)
- driver.maximize_window()
- driver.get('press.htm')
- key_up_radio = driver.find_element_by_id('r1') # 监测按键升起key_down_radio = driver.find_element_by_id('r2') # 监测按键按下key_press_radio = driver.find_element_by_id('r3') # 监测按键按下升起enter = driver.find_elements_by_xpath('//form[@name="f1"]/input')[1] # 输入框result = driver.find_elements_by_xpath('//form[@name="f1"]/input')[0] # 监测结果# 监测key_downkey_down_radio.click()
- ActionChains(driver).key_down(Keys.CONTROL, enter).key_up(Keys.CONTROL).perform()print result.get_attribute('value')# 监测key_upkey_up_radio.click()
- enter.click()
- ActionChains(driver).key_down(Keys.SHIFT).key_up(Keys.SHIFT).perform()print result.get_attribute('value')# 监测key_presskey_press_radio.click()
- enter.click()
- ActionChains(driver).send_keys('a').perform()print result.get_attribute('value')
- driver.quit()242526272829303132333435
结果:
- key downed charCode=[0] keyCode=[17] CTRLkey upped charCode=[0] keyCode=[16] NONEkey pressed charCode=[97] keyCode=[0] NONE123
示例2:
代码:
- # -*- coding: utf-8 -*-from selenium import webdriverfrom selenium.webdriver.common.action_chains import ActionChainsfrom selenium.webdriver.common.keys import Keysfrom time import sleep
- driver = webdriver.Firefox()
- driver.implicitly_wait(10)
- driver.maximize_window()
- driver.get('hel.htm')
- input1 = driver.find_elements_by_tag_name('input')[3]
- input2 = driver.find_elements_by_tag_name('input')[4]
- action = ActionChains(driver)
- input1.click()
- action.send_keys('Test Keys').perform()
- action.key_down(Keys.CONTROL).send_keys('a').key_up(Keys.CONTROL).perform() # ctrl+aaction.key_down(Keys.CONTROL).send_keys('c').key_up(Keys.CONTROL).perform() # ctrl+caction.key_down(Keys.CONTROL, input2).send_keys('v').key_up(Keys.CONTROL).perform() # ctrl+vprint input1.get_attribute('value')print input2.get_attribute('value')
- driver.quit()2425262728
结果:
- Test Keys
- Test Keys12
复制粘贴用WebElement< input >.send_keys()也能实现,大家可以试一下,也可以用更底层的方法,同时也是os弹框的处理办法之一的win32api,有兴趣也可以试试SendKeys、keybd_event
‘柒’ selenium2+python 如何把鼠标定位在网页中一个元素上,类似于hover那种
关键是正常的下拉框是需要点击的,我个人觉得可能是你网页的Select元素本身设计开发的有问题。
‘捌’ python3+selenium自动化测试-下拉选择框13
(13)下拉选择框
selenium的下拉选择框。我们通常会遇到两种下拉框,一种使用的是html的 标签select ,另一种是使用 input标签 做的假下拉框。
标签select :需要用到 Select类 ,先要导入select方法,
from selenium.webdriver.support.select import Select
input标签 :通常的处理方式与其他的元素类似,点击或使用JS等。
认识一下select下拉框选择:
<select id="nr" name="NR">
<option selected="" value="10">每页显示10条</option>
<option value="20">每页显示20条</option>
<option value="50">每页显示50条</option>
定位:
1、通过select选项的索引来定位选择对应选项(从0开始计数),如选择第三个选项:select_by_index(2)
2、通过选项的value值来定位,select_by_value("20")
3、通过选项的文本内容来定位。select_by_visible_text("每页显示50条")
Select提供了三种 选择方法 :
select_by_index(index) ——通过选项的顺序,第一个为 0
select_by_value(value) ——通过value属性
select_by_visible_text(text) ——通过选项可见文本
同时,Select提供了四种方法 取消选择 :
deselect_by_index(index) --取消对应index选项
deselect_by_value(value) --取消对应value选项
deselect_by_visible_text(text) --取消对应文本选项
deselect_all() --取消所有选项
Select为你提供了相应的方法(或者应该说是属性了),用来查看选中了哪一项:
options ——提供所有的选项的列表,其中都是选项的WebElement元素
all_selected_options ——提供所有被选中的选项的列表,其中也均为选项的WebElement元素
first_selected_option ——提供第一个被选中的选项,也是下拉框的默认值