python selenium语法_Selenium3+python3自动化(七)--CSS定位语法

前言

大部分人在使用selenium定位元素时,用的是xpath定位,因为xpath基本能解决定位的需求。css定位往往被忽略掉了,其实css定位也有它的价值,css定位更快,语法更简洁。

一、css:属性定位

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

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

3.css用#表示id属性,如:#kw;也可以写成[id=‘kw‘]

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

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

# coding:utf-8

from selenium import webdriver

driver=webdriver.Chrome()

driver.get("https://www.baidu.com")

#css通过id属性定位

# driver.find_element_by_css_selector("#kw").send_keys("xixi")

#css通过class属性定位

# driver.find_element_by_css_selector(".s_ipt").send_keys("hehe")

#css通过标签属性定位,这里运行会报错,主要是了解这个写法

driver.find_element_by_css_selector("input").send_keys("wrong")

二、css:其它属性

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

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

# coding:utf-8

from selenium import webdriver

driver=webdriver.Chrome()

driver.get("https://www.baidu.com")

#css通过name属性定位

# driver.find_element_by_css_selector("[name=‘wd‘]").send_keys("xixi")

#css通过autocomplete属性定位

driver.find_element_by_css_selector("[autocomplete=‘off‘]").send_keys("hehe")

三、css:标签

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

# coding:utf-8

from selenium import webdriver

driver=webdriver.Chrome()

driver.get("https://www.baidu.com")

#css通过标签与class属性的组合定位

# driver.find_element_by_css_selector("input.s_ipt").send_keys("xixi")

#css通过标签与id属性的组合定位

# driver.find_element_by_css_selector("input#kw").send_keys("hehe")

#css通过标签与其它属性组合定位

driver.find_element_by_css_selector("input[autocomplete=‘off‘]").send_keys("hua")

四、css:层级关系

1.在前面一篇xpath中讲到层级关系定位,这里css也可以达到同样的效果

2.如xpath://form[@id=‘form‘]/span/input 也可以用css实现;

# coding:utf-8

from selenium import webdriver

driver=webdriver.Chrome()

driver.get("https://www.baidu.com")

#xpath

#driver.find_element_by_xpath("//form[@id=‘form‘]/span/input").send_keys("hu")

# driver.find_element_by_xpath("//span/*[@name=‘wd‘]").send_keys("hehe")

#css通过层级关系定位

#driver.find_element_by_css_selector("form#form>span>input").send_keys("hehe")

driver.find_element_by_css_selector("span>input[name=‘wd‘]").send_keys("hehe")

五、css:索引

1.以下图为例,跟上一篇一样

2.css也可以通过索引a:nth-child(1)来定位元素

# coding:utf-8

from selenium import webdriver

driver=webdriver.Chrome()

driver.get("https://www.baidu.com")

#选择第一个a

driver.find_element_by_css_selector("div[id=‘s-top-left‘]>a:nth-child(1)").click()

#选择第3个a

# driver.find_#element_by_css_selector("div#s-top-left>a:nth-child(3)").click()

六、css:逻辑运算

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

# coding:utf-8

from selenium import webdriver

driver=webdriver.Chrome()

driver.get("https://www.baidu.com")

# driver.find_element_by_css_selector("input#kw[name=‘wd‘]").send_keys("he")

driver.find_element_by_css_selector("input[id=‘kw‘][name=‘wd‘]").send_keys("xixi")

七、css模糊匹配

[abc^="def"] 选择 abc 属性值以 "def" 开头的所有元素

[abc$="def"] 选择 abc 属性值以 "def" 结尾的所有元素

[abc*="def"] 选择 abc 属性值中包含子串 "def" 的所有元素

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值