python+selenium页⾯⾃动化元素定位实际遇到的各种问题(持续
更新)
jquery滚动条滚动到底部1、class属性有空格(已验证)
当classname 中存在空格的时候,直接使⽤find_element_by_class_name时,会显⽰定位失败,此时,需要将classname中的空格替换成英⽂的点“.”,如下图:
此时如果使⽤ find_element_by_class_name("link detail"),则提⽰⽆法定位该元素
如果使⽤英⽂点替换,则可以正常定位 find_element_by_class_name("link.detail")
如果class有多个值,中间⽤空格分开,可以只⽤其中⼀个值(如果唯⼀)进⾏定位。⽐如find_element_by_class_name("link")
2、上传⽂件
⽤AutoIt上传⽐较⿇烦,到上传的input标签,就可以通过send_keys()实现上传:将本地⽂件的路径作为⼀个值放在input标签中,通过form表单将这个值提交给服务器。
如上图所⽰,定位到⽂件输⼊框,对应的是位置1 ,但是真正上传的input标签是位置2 id=upfile(上传⽂件的意思),脚本如下:
find_element((By.ID,'upfile')).send_keys(file_path)
3、⽂件下载
⽅法⼀:(不推荐使⽤)
1、设置⽕狐浏览器⾃动下载到默认路径,不跳出确认框。
2、到浏览器配置⽂件夹路径:帮助菜单—故障排除信息——配置⽂件夹-打开⽂件夹——获取⽂件夹路径fp
3、driver=webdriver.Firefox(firefox_profile=fp) (不加firefox_profile参数打开的⽕狐是原⽣的浏览器,很⼲净什么插件都没有)
这时⾃动化脚本打开的就是实际使⽤的⽕狐,如果收藏地址、插件较多的话,打开会很慢。
⽅法⼆:(推荐)
通过设置浏览器参数
option = webdriver.ChromeOptions()
prefs = {'profile.default_content_settings.popups': 0, 'download.default_directory': export_path} # 设置下载路径,关闭确认弹出框。
option.add_experimental_option('prefs', prefs)
driver = webdriver.Chrome(chrome_options=option)
以上是chrome的设置⽅法,firefox类似。
4、/.. 定位返回上级节点和parent 效果⼀样
⽅法1://td[@title='admin']/parent::tr
⽅法2://td[@title='admin']/.. 更简单明了
5、following 结合 / 、// 的⽤法深⼊分析
following: 选取⽂档中当前节点的结束标签之后的所有节点,除属性节点(节点中的属性)和命名空间节点(类似这样的节点<div> </div>??)之外,如果当前节点有⼦节点,则包含其所有⼦节点。
xxx / following:: 选取xxx结束标签之后的所有节点,不包括xxx的所有⼦节点。 '/' 表⽰从xxx后进⾏定位,
xxx // following:: 选取xxx结束标签之后的所有节点,包括xxx的所有⼦节点。'//' 表⽰可以从xxx 任意⼀级⼦节点进⾏定位,以及xxx节点后进⾏定位。
如上图想定位到第⼀个input节点
定位1://div[@id='History_Table']/following::input[1]
结果:没有匹配元素,
原因:需要定位input属于当前节点div[@id='History_Table']的⼦节点,⽽/ following 不包括当前节点的⼦节点。
定位2://div[@id='History_Table']//following::input[1]
结果:匹配到了当前节点中3个input⼦节点。
原因:// following 从当前节点后的任意⼀级⼦节点进⾏定位,所以3个都能匹配到。
//div[@id='History_Table']//following::input[2] 则匹配后2个
//div[@id='History_Table']//following::input[3] 则匹配最后⼀个
定位3://div[@id='History_Table']/descendant::input[1]
结果:成功定位到了第⼀个input
原因:descendant 选取当前节点的所有后代元素,/ descendant 从当前节点后进⾏定位,所以唯⼀
如果改成 //div[@id='History_Table']//descendant::input[1] 则匹配3个,因为// descendant 从当前节点中任意⼀级⼦节点进⾏定位。
对于following::元素节点[num] 这种形式的定位,总结如下
1)、如果定位的元素节点不在⼦节点内,那么/和// 使⽤没有区别。
2)、如果定位的元素节点只在⼦节点内,那么使⽤following时只能使⽤//,但会出现定位到多个元素。建议使⽤ / descendant。(//descendant 在任意⼀级⼦节点进⾏定位)
3)、如果定位的元素节点既在⼦节点内,⼜在节点外,如果你想定位的是⼦节点内的,则⽤ /descendant ; 如果想定位的是节点外的,使
⽤/following,不能使⽤//following,因为⼦节点内的元素节点存在,会出现定位到多个元素。
6、Xpath 的常见函数
last() 最后⼀个节点数
.//*[@id='select2-drop']/ul/li[last()] last()是代表最后⼀个li。可以运算last()-3
count(node-set) 返回节点集node-set中的节点数
可以⽤于统计
7、页⾯滚动条滑动
ute_script("window.scrollTo(0,document.body.scrollHeight);") # 将页⾯滚动条滑到底部
ute_script("arguments[0].scrollIntoView();", el) # 向下滑动滚动条,跳转到⽬标元素处
ute_script("arguments[0].scrollIntoView(false);", el) # 向上滑动滚动条,跳转到⽬标元素处
arguments[0].scrollIntoView(),不能随意使⽤,会先把元素element对象的表格“顶端”移动到与当前窗⼝的“顶部”对齐,如果元素当前可见,可能移动后就不可见了,导致定位报错。因为会把元素顶端对齐窗⼝顶部,有时候也会出现跳转后,元素仍然不可见的情况。如果是需要点击这个元素,可以使⽤下⾯这种⽅式:
ute_script("arguments[0].click();", el) # 直接点击不可见的⽬标元素,不再先跳转。
8、获取某节点下⼦节点个数
获取div节点下li的节点个数
法⼀:num=ute_script("return $('.jspPane').find('li').length;") # JQuery写法 , 要加上return 才能获取js执⾏的值
法⼆:num=ute_script('ElementsByClassName("jspContainer")[0].getElementsByTagName("li").length;') #DOM写法
9、selenium 获取元素⽂本值
self.drive.find_element(*loc).text ⽂本值加载需要时间,获取⽂本值前常常需要sleep⼀下否则就可能获取为空值或者获取的不是最新的⽂本值,有没有更好的⽅法呢?
10、使⽤find_element() ,如果页⾯上有符合条件的多个元素时,find_element 只会到符合条件的第⼀个元素!不会报错。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论