自动化selenium 基本 *** 作方法总结

自动化selenium 基本 *** 作方法总结,第1张

# 定位 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高级 *** 作等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/9728825.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存