python怎么鼠标定位id,Selenium2+python自动化45-18种定位方法(find_elements)

江湖传言,武林中流传八种定位,其中xpath是宝刀屠龙,css是倚天剑。

除了这八种,其实还有十种定位方法,眼看就快失传了,今天小编让失传已久的定位方法重出江湖!

一、十八种定位方法

前八种是大家都熟悉的,经常会用到的

使用webdriver.的find_element方法

self.driver.find_element()

八种定位方法统一使用的是:self.find_element(by=By.XPATH,value=xpath)

1.id定位:id在HTML界面中是唯一的存在

find_element_by_id("id定位表达式")

2.name定位:根据元素的name属性来定位

find_element_by_name(name定位表达式)

3.class定位:根据元素的class属性来定位

find_element_by_class_name(name定位表达式)

4.tag定位:页面html文档下的各种标签,find_element_by_tag_name("input");或者find_element(by.ag_name,“元素表达式”)

tag往往用来定义一类功能,所以通过tag识别某个元素的概率很低。任意打开一个页面,都会发现大量的

、、 等tag,所以tag name定位很少用

find_element_by_tag_name(self, name)

5.link定位:专门用来定位文本链接

find_element_by_link_text(self, link_text)

6.partial_link定位:

find_element_by_partial_link_text(self, link_text)

7.xpath定位:

find_element_by_xpath('元素定位表达式')

a./:通过绝对路径来定位

b.//:通过相对路径来定位(建议使用相对路径)

c.//标签名[@属性名='属性值']:通过属性定位于元素若不想指定标签名可以通过通配符*来代替,*匹配所有元素节点

d.//标签名[text()='xxxxxxx']:通过元素的text内容进行定位

d:函数使用:

text():元素的text内容

contains(@属性/text(),value):包含函数。例:contains(@class,"XXXX")、contains(text(),"XXXX")

e.逻辑运算

and 表示条件与。

or 表示条件或。

例://div[@class="XXX" and contains(@style,"display:visibility")]

f.轴运算

ancestor:祖先结点 包括父

parent:父结点

preceding: 当前元素节点标签之前的所有结点。(html页面先后顺序)

例://div//table//td//preceding::td

preceding-sibling: 当前元素节点标签之前的所有兄弟结点

following: 当前元素节点标签之后的所有结点。(html页面先后顺序)

following-sibling:当前元素节点标签之后的所有兄弟结点

e:层次关系

//div[@id="u1"]//a[@name="tj_login" and text()="登录"]。用相对定位来定位

8.css定位:find_element_by_css_selector(self, css_selector)

9.By定位:driver.find_element(By.定位方式,'元素定位表达式')

from selenium.webdriver.common.by import By #使用By这种定位前要将By类导入

find_element(By.ID,"loginName")

find_element(By.NAME,"SubjectName")

find_element(By.CLASS_NAME,"u-btn-levred")

find_element(By.TAG_NAME,"input")

find_element(By.LINK_TEXT,"退出")

find_element(By.PARTIAL_LINK_TEXT,"退")

find_element(By.XPATH,".//*[@id='Title")

find_element(By.CSS_SELECTOR,"[type=submit]")

这八种是复数形式

a.批量操作对象,如选中页面上所有复选框

b.先获取一组对象,再在这组对象里定位需要的的一些对象,如定位所有复选框,然后选择最后一个

9.id复数定位find_elements_by_id(self, id_)

10.name复数定位find_elements_by_name(self, name)

11.class复数定位find_elements_by_class_name(self, name)

12.tag复数定位find_elements_by_tag_name(self, name)

13.link复数定位find_elements_by_link_text(self, text)

14.partial_link复数定位find_elements_by_partial_link_text(self, link_text)

15.xpath复数定位find_elements_by_xpath(self, xpath)

16.css复数定位find_elements_by_css_selector(self, css_selector

这两种就是快失传了的

find_element(self, by='id', value=None)

find_elements(self, by='id', value=None)

二、element和elements傻傻分不清

1.element方法定位到是是单数,是直接定位到元素

2.elements方法是复数,这个学过英文的都知道,定位到的是一组元素,返回的是list队列

3.可以用type()函数查看数据类型

4.打印这个返回的内容看看有什么不一样

cfd97dcbf42b90dc871e22a78e8fac90.png

三、elements定位方法

1.前面一篇已经讲过find_element()的用法,看这里:

2.这里重点介绍下用elements方法如何定位元素,当一个页面上有多个属性相同的元素时,然后父元素的属性也比较模糊,不太好定位。

这个时候不用怕,换个思维,别老想着一次定位到,可以先把相同属性的元素找出来,取对应的第几个就可以了。

3.如下图,百度页面上有六个class一样的元素,我要定位“地图”这个元素

c333f9e938c843fab3898045fb1dd775.png

4.取对应下标即可定位了

cb15dff77e62cc7f967e332a18f57c6b.png

四、参考代码

# coding:utf-8

from selenium import webdriver

driver = webdriver.Firefox()

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

# 这里是定位的单个id

element = driver.find_element_by_id("kw")

print type(element)

print element

# 这里定位是多个class

elements = driver.find_elements_by_class_name("mnav")

print type(elements)

print elements

# 这里用的css语法

s = driver.find_elements("css selector", ".mnav")

# '地图'在第四个位置

print s[3].text

s[3].click()

# 这个写法也是可以的

# driver.find_elements("css selector", ".mnav")[3].click()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值