博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
selenium3 + python - css定位
阅读量:4587 次
发布时间:2019-06-09

本文共 2566 字,大约阅读时间需要 8 分钟。

一、css:属性定位

    1.css可以通过元素的id、class、标签这三个常规属性直接定位到

    2.如下是百度输入框的的html代码:

<input id="kw" class="s_ipt" type="text" autocomplete="off" maxlength="100" name="wd"/>

    3.css用#号表示id属性,如:#kw

    4.css用.表示class属性,如:.s_ipt

    5.css直接用标签名称,无任何标示符,如:input

 

from selenium import webdriver driver = webdriver.Chrome() driver.get("http://www.baidu.com") #用css通过id属性定位 driver.find_element_by_css_selector("#kw").send_keys("selenium") #用css通过class属性定位 driver.find_element_by_css_selector(".s_ipt").send_keys("selenium")

二、css:其它属性

    1.css除了可以通过标签、class、id这三个常规属性定位外,也可以通过其它属性定位

    2.以下是定位其它属性的格式

from selenium import webdriver driver = webdriver.Chrome() driver.get("http://www.baidu.com") #用css通过autocomplete属性定位 driver.find_element_by_css_selector("[autocomplete='off']").send_keys("selenium") #用css通过name属性定位 driver.find_element_by_css_selector("[name='wd']").send_keys("selenium") #用css通过type属性定位 driver.find_element_by_css_selector("[type='text']").send_keys("selenium")

三、css:标签

    1.css页可以通过标签与属性的组合来定位元素

from selenium import webdriver driver = webdriver.Chrome() driver.get("http://www.baidu.com") #用css通过标签与name属性定位 driver.find_element_by_css_selector("input.wd").send_keys("selenium") #用css通过标签与id属性定位 driver.find_element_by_css_selector("inout#kw").send_keys("selenium")

四、css:层级关系

 1.如xpath://form[@id='form']/span/input 和 //form[@class='fm']/span/input也可以用css实现

from selenium import webdriver driver = webdriver.Chrome() driver.get("http://www.baidu.com") #css通过层级关系定位 driver.find_element_by_xpath("span#s_kw_wrap>input").send_keys("selenium") driver.find_element_by_xpath("form.fm>span>input").send_keys("selenium")

五、css:索引

 

   1.css也可以通过索引option:nth-child(1)来定位子元素,这点与xpath写法用很大差异,其实很好理解,直接翻译过来就是第几个小孩 

#选择第一个option driver.find_element_by_css_selector("select#nr>option:nth-child(1)").click() #选择第二个option driver.find_element_by_css_selector("select#nr>option:nth-child(2)").click() #选择第三个option driver.find_element_by_css_selector("select#nr>option:nth-child(3)").click()
六、css:逻辑运算

    1.css同样也可以实现逻辑运算,同时匹配两个属性,这里跟xpath不一样,无需写and关键字 

from selenium import webdriver driver = webdriver.Chrome() driver.get("http://www.baidu.com") driver.find_element_by_css_selector("input[id='kw'][name='wd']").send_keys("selenium") 七、css:模糊匹配 

 1.css的模糊匹配contains('xxx'),网上虽然用各种资料显示能用,但是小编亲自试验了下,一直报错。

 2.在各种百度后找到了答案:you can't do this with CSS selectors, because there is no such thing as:contains() in CSS. It was a proposal that was abandoned years ago.非常遗憾,这个语法已经被抛弃了,所以这里就没继续研究了。

css语法远远不止上面提到的,还有更多更强大定位策略,有兴趣的可以继续深入研究。官方说法,css定位更快,语法更简洁,但是xpath更直观,更好理解一些。

 

转载于:https://www.cnblogs.com/Teachertao/p/10965022.html

你可能感兴趣的文章
C#打印成绩表代码
查看>>
1、HA Cluster基础原理
查看>>
cellmap 基站查询 for android
查看>>
jjava:将jar包引入环境变量的一个骚操作以及因此搞出来的扑街问题
查看>>
BZOJ3083 遥远的国度(树链剖分+线段树)
查看>>
ionic的常用命令总结以及正式发布的准备
查看>>
419. Battleships in a Board
查看>>
hdoj_1556Color the ball
查看>>
Docker容器技术入门
查看>>
floor(x) 函数
查看>>
实现多线程的方式
查看>>
ckplayer+barrage 视频弹幕
查看>>
js实现左右点击图片层叠滚动特效
查看>>
【VS开发】CTabView多页卡界面
查看>>
mysql安装
查看>>
Spring 源码分析之 bean 依赖注入原理(注入属性)
查看>>
CFileFind类的使用总结 .
查看>>
[转]asp.net 防止外部提交数据
查看>>
android用户界面之Gallery3D学习资料汇总
查看>>
[编写高质量代码:改善java程序的151个建议]建议62 警惕数组的浅拷贝
查看>>