前言
都是个人踩坑经验哦,用到了辛苦关注下!
1.浏览器出现新的页面
点击新建等按钮时,浏览器自动弹出了一个新页面,并显示新页面。接下来需要在新页面上继续自动化操作。
需要调用:
driver.switch_to.window(driver.current_window_handle)
来切换window,否则还是在原来的网页继续搜索元素。
2.下拉选框的选择
如果审查元素发现该控件的标签是Select类型:
//使用Select函数需要先导入
from selenium.webdriver.support.ui import Select
Select(driver.find_element_by_name('country')).select_by_visible_text(u'中国')
如果这不是Select标签类型的下拉选择框,则考虑展开后,鼠标点击对应选项元素,然后按下键盘的回车Enter按键。
driver.find_element_by_css_selector('xxx').send_keys(Keys.ENTER)
常用的键盘事件
# Keys.BACK_SPACE:回退键(BackSpace)
# Keys.TAB:制表键(Tab)
# Keys.ENTER:回车键(Enter)
# Keys.SHIFT:大小写转换键(Shift)
# Keys.CONTROL:Control键(Ctrl)
# Keys.ALT:ALT键(Alt)
# Keys.ESCAPE:返回键(Esc)
# Keys.SPACE:空格键(Space)
# Keys.PAGE_UP:翻页键上(Page Up)
# Keys.PAGE_DOWN:翻页键下(Page Down)
# Keys.END:行尾键(End)
# Keys.HOME:行首键(Home)
# Keys.LEFT:方向键左(Left)
# Keys.UP:方向键上(Up)
# Keys.RIGHT:方向键右(Right)
# Keys.DOWN:方向键下(Down)
# Keys.INSERT:插入键(Insert)
# DELETE:删除键(Delete)
# NUMPAD0 ~ NUMPAD9:数字键1-9
# F1 ~ F12:F1 - F12键
# (Keys.CONTROL, ‘a’):组合键Control+a,全选
# (Keys.CONTROL, ‘c’):组合键Control+c,复制
# (Keys.CONTROL, ‘x’):组合键Control+x,剪切
# (Keys.CONTROL, ‘v’):组合键Control+v,粘贴
3.元素定位方法汇总
4.重要 - 切换Frame
如果html标签内嵌了html标签,那么可以在检查网页元素的debug模式下搜索frame关键字,很有可能是出现了内嵌frame需要切换context(上下文)。
常见场景:
从网页右键拷贝得到了元素的xpath或者css selector。该元素也显示在界面上。
却报错:
selenium.common.exceptions.NoSuchElementException: Message: no such element: Unable to locate element:
就有可能是上下文发生了更换,而没有切换到对应的frame。
# 选择 模板 按钮,在新的二级html里面,需要切换frame,切换frame可能需要时间,尝试适当sleep
editorFrame = driver.find_element_by_tag_name('iframe')
driver.switch_to.frame(editorFrame)
sleep(2)
driver.find_element_by_xpath('//*[@id="editor"]/div/div[2]/a').click()
sleep(1)
# 选择:公开课-报名须知,在新的三级html里面,需要切换frame
templateFrame = driver.find_element_by_xpath('//*[@id="dialog-select"]/div/div[2]/span/iframe')
driver.switch_to.frame(templateFrame)
sleep(2)
driver.find_element_by_xpath('//*[@id="grid-form"]/table/tbody/tr[2]/td/a').click()
其中的editorFrame和templateFrame是页面内Tab下的iFrame标签下的html子标签,在网页上右键-选择审查元素,然后进行搜索关键字frame即可。
5.常见报错:element not interactble
尝试在操作之前增加sleep(5),等待系统元素树重载。
经验之谈:在页面发生转换、浮层切换,弹窗等焦点切换的场景下,尽量等待下再进行操作。
说人话:就是涉及页面大面积更换或者创建了新的弹窗、浮层等UI变动,如果报这个错误就sleep一会。
6.属性几乎相同的div等元素-如何定位?
场景截图:
通过右击,查看元素,发现各个元素的各种属性都一样(不要疑惑,存在这种不规范的开发导致没有ID区分这几个元素,因为就是开发复制粘贴的代码)。
那么我要上传图片到指定的那一行怎么办呢?
接下来认识xpath的函数!
driver.findElement(By.xpath("//div[text()=\"A\"]")).click();
html源码的Demo参考:
<html>
<body>
<input type='checkbox' name='chk'>first
<br><input type='checkbox' name='chk'>选项1
<br><input type='checkbox' name='chk'>选项2
<br><input type='checkbox' name='chk'>选项3
<br><input type='checkbox' name='chk'>选项4
<br><input type='checkbox' name='chk'>选项5
</body>
</html>
xpath支持的一些函数
Node set : last(), position(), count(), id(), local-name(), namespace-uri(), name()
String : string(), concat(), starts-with(), contains(), substring-before(), substring-after(), substring(), string-length(), normalize-space(), translate()
Boolean : boolean(), not(), true(), false(), lang()
Number : number(), sum(), floor(), ceiling(), round()
last() 函数,
last()-3 函数,
position()=4 函数。
都可以对属性相近的一列元素进行index定位。
//input[contains(@class, 'suggest')]
格式:
find_element_by_xpath('(xpath集合结果取值的表达式)[函数表达式]')
7.上传图片文件(文件上传框)
# App配图的「上传」按钮:向上传按钮发送file路径 key。同名元素可以使用函数position=3来定位
# python调用xpath函数方法
driver.find_element_by_xpath('(//*[@id="uploadifive-undefined"]/input)[position()=3]').send_keys('/Users/lipeng/Downloads/Locators_groups_1_0_2.jpg')
8.键盘&鼠标的操作调用
from selenium.webdriver import ActionChains
# 记得执行perform来调用队列中的操作。
actions = ActionChains(driver)
actions.move_to_element(menu)
actions.click(hidden_submenu)
actions.perform()
9.Chrome Version报错
selenium.common.exceptions.SessionNotCreatedException: Message: session not created: Chrome version must be between 70 and 73
(Driver info: chromedriver=73.0.3683.68 (47787ec04b6e38e22703e856e101e840b65afe72),platform=Mac OS X 10.14.4 x86_64)
原因:Chrome版本和Chrome Driver版本不匹配
因为driver是我们手动从网站上下载的,而很多人的Chrome可能开启了自动更新功能。
随着使用的过程,Chrome版本过于新,导致driver不支持,此时需要重新从网站上下载新的Chrome Driver进行更换。