Webdriver元素定位的方法

webdriver提供了8种元素定位方法:

1、id

2、name

3、tag name

4、class name

5、link text

6、partial link text

7、xpath

8、css

以百度首页搜索输入框为例

 

加载浏览器;

from selenium import webdriver

driver = webdriver.Chrome()

1 使用ID定位搜索输入框:

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

driver.find_element_by_id('kw')

2 使用name定位搜索输入框:

driver.find_element_by_name('wd')

3 使用tag name搜索输入框:

driver.find_element_by_tag_name('input')

driver.find_elements_by_tag_name('input')[1]

4 使用class name 定位:

driver.find_element_by_class_name('s_ipt')

5 使用link text定位“新闻“”链接:

<a href="http://news.baidu.com" target="_blank" class="mnav">新闻</a>

driver.find_element_by_link_text("新闻")

6 使用partial link text定位:

driver.find_element_by_partial_link_text("新")

7 使用css定位搜索输入框:

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

a  css通过id定位时,使用"#"表示元素的id

driver.find_element_by_css_selector("#kw")

b css通过class name定位时,使用".",表示class name

driver.find_element_by_css_selector(".s_ipt")

c css通过tag name定位时,直接使用元素的标签

driver.find_element_by_css_selector("input")

d css通过其它属性定位时,直接使用元素的标签

driver.find_element_by_css_selector("[autocomplete='off']") #注意单双引号的使用

driver.find_element_by_css_selector("[maxlength='255']")

e css定位,可以在参数中加入元素的标签名称

driver.find_element_by_css_selector("input#kw")

driver.find_element_by_css_selector("input.s_ipt")

driver.find_element_by_css_selector("input[autocomp='off']")

f css的层级定位

driver.find_element_by_css_selector("form#form>span:nth-child(1)>input")

g css的逻辑运算

用有一个元素来定位元素时,如果有其他元素的属性和此元素重复,可以组合多个属性来共同定位

组合多个属性定位元素定位百度搜索框

driver.find_element_by_css_selector('input[id="kw"] and [name="wd"]')

8 使用xpath定位:

a 使用元素定位

driver.find_element_by_xpath("//input[@id='kw']")

driver.find_element_by_xpath("//input[@name='wd']")

driver.find_element_by_xpath("//input[@class='s_ipt']")

b xpath层级定位

driver.find_element_by_xpath("//input[@id='form']//span[1]//input")

driver.find_element_by_xpath("//[@class='fm']//span[1]//input")

 

转载于:https://www.cnblogs.com/holly-j/p/8444811.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值