# 定位 UI 元素 (WebElements)
find_element_by_id
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
# 获取元素数据
eleget_attribute('href')
eletext
eleinner
eleget_attribute('outerHTML')
eleget_attribute('innerHTML')
# 导入 ActionChains 类
from seleniumwebdriver import ActionChains
# 鼠标移动到 ac 位置
ac = driverfind_element_by_xpath('element')
ActionChains(driver)move_to_element(ac)perform()
# 在 ac 位置单击
ac = driverfind_element_by_xpath("elementA")
ActionChains(driver)move_to_element(ac)click(ac)perform()
# 在 ac 位置双击
ac = driverfind_element_by_xpath("elementB")
ActionChains(driver)move_to_element(ac)double_click(ac)perform()
# 在 ac 位置右击
ac = driverfind_element_by_xpath("elementC")
ActionChains(driver)move_to_element(ac)context_click(ac)perform()
# 在 ac 位置左键单击 hold 住
ac = driverfind_element_by_xpath('elementF')
ActionChains(driver)move_to_element(ac)click_and_hold(ac)perform()
# 将 ac1 拖拽到 ac2 位置
ac1 = driverfind_element_by_xpath('elementD')
ac2 = driverfind_element_by_xpath('elementE')
ActionChains(driver)drag_and_drop(ac1, ac2)perform()
# 导入 Select 类
from seleniumwebdriversupportui import Select
select = Select(driverfind_element_by_name('status')
selectselect_by_visible_text("审核不通过")
# 页面切换
driverswitch_towindow("window name")
# *** 作页面的前进和后退
driverforward()
driverback()
# 页面等待
## 隐式等待
driverimplicitly_wait(10)
## 显示等待
try: # 页面一直循环,直到 id="myElement" 出现
element = WebDriverWait(driver, 10)until(ECpresence_of_element_located((ByID, "myElement")))
finally:
driverquit()
dim x,y,color
//声明变量
GetCursorPos x, y
//得到当前鼠标的坐标位置 并保存到变量x,y中
Color=GetPixelColor(x,y)
//得到指定坐标位置的颜色 并保存到变量color中
MessageBox("坐标为:"&x&","&y&" 颜色为:"&color)
//d出窗口 输出坐标和颜色的值
本章节主要内容:
switch_to适用场景:
处理JSd框
切换frame
切换浏览器窗口
Switch_to处理JSd框
JavaScript简称JS,应用于HTML网页,通过 *** 纵网页窗口及网页元素,从而实现动态效果。
JSd框类型:警告框alert、确认框confirm、提示框prompt
浏览器窗口中如果有JavaScript的d出框,需要通过switch_to语句处理。
相关方法:
Switch_to切换窗口
浏览器中有多个窗口时,如果想切换到其他窗口 *** 作,需要调用switch_to方法
切换到目标窗口:
相关方法:
示例:
Switch_to切换frame
如果元素在html的frame或iframe中,则无法直接定位到元素。需要先切换到该frame中,再进行定位及其他 *** 作。
相关方法:
一般来说我们与页面的交互可以使用WebElement的方法来进行点击等 *** 作。但是有时候我们需要一些更复杂的动作,就需要用到我们的Action Chains了。
通过action对象模拟鼠标 *** 作,如双击,右击,拖拽,悬停等 *** 作:
普通键:
有名按键:
无名按键:a-z,0-9
修饰键:
修饰键单独使用没有意义,一般和别的按键配合使用。
Actions *** 作:
使用示例
输入大写或按键上方的字符:
JS,JavaScript的简称,广泛用于HTML网页,通过 *** 纵网页窗口及网页元素,从而实现动态效果。
webdriver无法完成的 *** 作,可以由JS配合完成。
示例:
参考JS:
获取标题:documenttitle
d出提示框:alert('我是一个d框');
改变元素属性:q=documentgetElementById('kw');qstyledisplay='block';
Selenium-JS处理滚动条
通过js实现滚动条拖动效果:
移动元素到窗口顶部:
移动元素到窗口底部:
窗口移动指定距离:
移动窗口到某位置:
input标签上传:借用input元素的sendkeys方法实现
示例:
非input标签上传---借用其他工具如autoIt:
• 用于Windows GUI自动化 *** 作
• 通过它可以组合使用模拟键击、鼠标移动和窗口/控件 *** 作等来实现自动化任务。
• 它使用类似BASIC的脚本语言。
• 可以通过转换工具把脚本转换为exe文件
应用程序从安全考虑,都在登录或某 *** 作节点使用验证码。
验证码是一种区分用户是计算机还是人的公共全自动程序。
自动化时验证码处理方式:
cookie的 *** 作:
Selenium-截图 *** 作
截图:
cpoint
酣窢丰喝莶估奉台斧郡pt;
::getcursorpos(&pt);
这样就可以得到当前鼠标的位置了,(ptx,pty)。
要获得鼠标点击时的坐标不用自己获得的,mfc的消息映射函数的参数中有鼠标位置的这个参数的。
以上就是关于自动化selenium 基本 *** 作方法总结全部的内容,包括:自动化selenium 基本 *** 作方法总结、按键精灵怎么获取屏幕鼠标坐标、自动化测试:Selenium高级 *** 作等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)