八种元素定位id,name,class_name,tag_name,link_text,partial_link_text,xpath,css<搬代码>

1.导包
2.2.指定浏览器(实例化浏览器对象)
3.打开i项目(就是网址)
4.找到元素定位
5.操作元素
6.暂停3s
7.关闭4

一案例实施步骤思路分析id要素

#导入selenium
From selenium import webdriver
From time import sleep
#实例化浏览器
Driver=webdriver.Firefox()
#打开项目
Driver.get(“http://www.baidu.com”)
#找到用户名文本框-定位元素(用户)
element=Driver.find_element_by_id(“userA”)
#给用户文本框传值
Element.send_keys(“admin”)
Pwd=driver.find_element_by_id(“passwordA”)
Pwd.send_keys(“123456”)
#暂停3s
Sleep(3)
#关闭浏览器
driver.quit()

二:
#导包
From selenium import webdriver
#实例化浏览器
driver=webdriver.Firefox()
Url=r”E:\xxxx\xxx\xxx” 双\转义
Url=r”E:\xxxx\xxx\xxx” r作用:被r修饰字符串,字符串中转义符不做转义使用
Url=r”file:///e:/xx/xx/xx”复制网址会乱码不影响
Driver.get(url)
#找文本框-定位元素-传值
Driver.find_element_by_id(“userA”).send_keys(“admin”)
Driver.find_element_by_id(“password”).send_keys(“123456”)
#暂停3s
Sleep(3)
#关闭浏览器
Driver.quit()
二案例实施步骤思路分析name要素

#导包
From selenium import webdriver
From time import sleep
#实例化浏览器对象
Driver=webdriver.Firefox()
#打开url
Driver.get(url)
#定位元素复制
Driver.find_element_by_name(“userA”).send_keys(“admin”)
Driver.find_element_by_name(“passwordA”).send_keys(“123456”)
##暂停3s
Sleep(3)
#关闭浏览器
Driver.quit()

三案例实施步骤思路分析class_name要素

From selenium import webdriver
From time import sleep

Driver=Webdriver.Firefox()
Driver.get(url)
Driver.find_element_by_class_name(“phone”).send_keys(“18611113333”)

#暂停3s
Driver.sleep(3)
#关闭浏览器
Deiver.quit()

四案例实施步骤思路分析tag_name要素tag标签
From selenium import webdriver
From time import sleep

Driver=Webdriver.Firxfox()
Url=””
Driver.get(url)
第一个元素,第二个元素如何获取呢?下一节讲
Driver.find_element_by_tag_name(“input”).send_keys(“admin”)

五案例实施步骤思路分析link_text超链接,全部匹配

From selenium import webdriver
From time import sleep

Driver=Webdriver.Firxfox()
Url=””
Driver.get(url)

Driver.find_element_by_link_text(“访问 新浪 网站”).click()

Sleep(3)
Driver.quit()

六案例实施步骤思路分析partial_link_text模糊匹配

From selenium import webdriver
From time import sleep
Driver=Webdriver.Firxfox()
Url=””
Driver.get(url)
Driver.find_element_by_partial_link_text(“访问”).click()
Sleep(3)
Driver.quit()

二元素定位
1.Id
说明:通过元素id属性定位–前提:元素必须有id属性
方法:Driver.find_element_by_id
2.name
说明:通过元素name 属性定位–前提:元素必须有name 属性
方法:Driver.find_element_by_name
3.Class_name
说明:通过元素Class_name 属性定位–前提:元素必须有Class属性
方法:Driver.find_element_by_Class_name
4.tag_name
说明:通过元素标签名称 属性定位–
前提:元素标签名在当前页面必须是唯一,或定位符合条件第一个元素
返回:符合条件的第一个元素
方法:Driver.find_element_by_tag_name

5.link_text
说明:只定位超链接标签
注意:必须为全部匹配文本
方法:find_element_by_link_text(全部文本值)
6.Partial_link_text
说明:他为link_text的补充说明明
注意:为模糊匹配
方法:find_element_by_Partial_link_text(局部文本值)

七:获取第二个文本框 tag_name
From selenium import webdriver
From time import sleep
Driver=Webdriver.Firxfox()
Url=””
Driver.get(url)

find_elements_by_tag_name(“input”)[2].send_keys(“123456”)
From selenium import webdriver
From time import sleep
Driver=Webdriver.Firxfox()

Driver.get(url)
find_element_by_tag_name(“input”).send_keys(“admin”)
Driver.find_elements_by_tag_name(“input”)[1].send_keys(“123456”)

Sleep(3)
Driver.quit()

在这里插入图片描述

在这里插入图片描述

Xpath,css定位

Xpath:
定位策略:
1.路径-定位1)绝对路径2)相对路径
2.利用元素属性定位
3.层级与属性结合定位
4.属性与逻辑结合定位
方法:find_element_by_xpath()
在这里插入图片描述

xpath案例
1.路径-定位1)绝对路径/html/body/form/div/fieldset/p[1]/input
2)相对路径//input[@id=’userA’]

From selenium import webdriver
From time import sleep
Driver=Webdriver.Firxfox()
Url=””
Driver.get(url)
#绝对路径
Driver.find_element_by_xpath(“/html/body/form/div/fieldset/p[1]/input”).send_keys(“admin”)
Driver.find_element_by_xpath(“/html/body/form/div/fieldset/p[2]/input”).send_keys(“123456”)
#相对路径
Driver.find_element_by_xpath(“//input[@id=’userA’]”).send_keys(“admin”)
Driver.find_element_by_xpath(“//input[@id=’passwordA’]”).send_keys(“123456”)
Sleep(3)
Driver.quit()
Driver.quit()
2.利用元素属性定位

From selenium import webdriver
From time import sleep
Driver=Webdriver.Firxfox()
Url=””
Driver.get(url)

Sleep(3)
Driver.quit()

3.层级与属性结合定位;*就是不知道是p还是a标签
在这里插入图片描述

说明:要找的元素没有属性,但他的父级有
示例://[@id=’p1’]/input 如: 【//p[@id=’p1’]/input】
/input[@id=”userA”]
//
[@id=’p1’]/input[@id=”userA”] 如:【//p[@id=’p1’]/input[@id=”userA”]】

4.属性与逻辑结合定位;*就是不知道是p还是a标签
在这里插入图片描述

说明:解决元素之间个相同属性崇明问题
示例://*[@id=’telA’ and @class=’telA’]
如://input[@name=’userA’ and class=’userA-test’]

5.xpath延申;*就是不知道是p还是a标签
在这里插入图片描述

//[text()=”xxx”] 文本内容是xxx的元素,xxx为全部匹配
//
[starts=with(@attribute,’xxx’)] 如://*[starts=with(@name,’us’)] us开头的
在这里插入图片描述

属性与逻辑,如果1定位不到就用2,2定位不到就用3,3定位不到就用4

Css定位:极力推荐css的
Css定位方法:driver.find_element_by_css_selector()
Css定位常用的策略:
1.id选择器
注意:id选择必须以#修饰; #id写成#userA driver.find_element_by_css_selector(“#userA”).send_keys(“admin”)
2.Class选择器
注意:class选择必须以.修饰; .class写成.telA driver.find_element_by_css_selector(“telA”).send_keys(“123456”)
3.元素选择器
在这里插入图片描述

格式:element 如:input <选择所有input元素>
4.属性选择器
在这里插入图片描述

格式:[attribute=value] 如: [type=”password”] <选择所有type属性值为password的值>

5.层级选择器
在这里插入图片描述

格式:element>element 如:1.p>input 2. p[id=p1] input 3. p>input[class=”telA”]

Id选择案例:
Form selenium import webdriver
Form time import sleep
Driver=Webdriver.Firefox()
Driver.get(“url”)

Driver.find_element_by_css_selector(“#userA”).send_keys(“admin”)
Driver.find_element_by_css_selector(“#passwordA”).send_keys(“123456”)
Sleep(3)
Driver.quit()

css延申
在这里插入图片描述

总结:
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值