首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
1
《手把手教你》系列基础篇之1-python+ selenium自动化测试-环境搭建(详细)
2
《手把手教你》系列基础篇之2-python+ selenium-打开和关闭浏览器(详细)
3
《手把手教你》系列基础篇之3-python+ selenium自动化测试-驱动浏览器和元素定位大法
4
🔥《手把手教你》系列基础篇之4-python+ selenium自动化测试-xpath使用(详细教程)
5
🔥《手把手教你》系列练习篇之1-python+ selenium自动化测试(详细教程)
6
《手把手教你》系列练习篇之2-python+ selenium自动化测试(详细教程)
7
《手把手教你》系列练习篇之3-python+ selenium自动化测试(详细教程)
8
《手把手教你》系列练习篇之4-python+ selenium自动化测试(详细教程)
9
《手把手教你》系列练习篇之5-python+ selenium自动化测试(详细教程)
10
《手把手教你》系列练习篇之6-python+ selenium自动化测试(详细教程)
11
《手把手教你》系列练习篇之7-python+ selenium自动化测试 -压轴篇(详细教程)
12
《手把手教你》系列练习篇之8-python+ selenium自动化测试 -压台篇(详细教程)
13
《手把手教你》系列练习篇之9-python+ selenium自动化测试 -番外篇 - 最后一波
14
python+ selenium自动化测试 - python基础扫盲
15
python+ selenium自动化测试 - python基础扫盲
16
《手把手教你》系列进阶篇之3-python+ selenium自动化测试 - python几种骚操作你都知道吗?(详细教程)
17
《手把手教你》系列进阶篇之4-python+ selenium自动化测试 - python几种超神操作你都知道吗?(详细教程)
18
《一头扎进》系列之Python+Selenium框架设计篇1- 价值好几K的框架,不看别后悔,过时不候
19
《一头扎进》系列之Python+Selenium框架设计篇2- 价值好几K的框架,不看白不看,看了还想看
20
《一头扎进》系列之Python+Selenium框架设计篇3- 价值好几K的框架,狼来了,狼来了....,狼没来,框架真的来了
21
《一头扎进》系列之Python+Selenium框架实战篇4- 价值好几K的框架,呵!这个框架有点意思啊!!!
22
《一头扎进》系列之Python+Selenium框架设计篇5 - 价值好几K的框架,哎呦!这个框架还真有点料啊!!!
23
《一头扎进》系列之Python+Selenium自动化测试框架实战篇6 - 价值好几K的框架,呦!这个框架还真牛叉哦!!!
24
《一头扎进》系列之Python+Selenium自动化测试框架实战篇7 - 年底了还没升职加薪,年终奖全靠它了!!!
25
《一头扎进》系列之Python+Selenium框架实战篇8 - 年底升职加薪,年终奖就差最后这一步你知道不???

《手把手教你》系列练习篇之2-python+ selenium自动化测试(详细教程)

1. 简介

今天我们还是继续练习练习基本功,各位小伙伴要耐住住性子,要耐得住寂寞啊,不要急躁,后面你会感谢你在前边的不断练习的。到后面也是检验你前边的学习成果的一次很好实践。

本文介绍如何通过link text、partial link text、class name和name 来定位页面元素。

2.link text定位元素

我们打开网页,一些可以点击的链接跳转上面的文字,就是link text,用百度首页举例来看:

在上面图中,这一排上面的文字都是link text,例如我们要通过“新闻”这个文本字段来定义这个跳转链接元素。

2.1 代码实现:

2.2 参考代码:

代码语言:javascript
复制
# coding=utf-8?

# 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2019-11-29
@author: 北京-宏哥   QQ交流群:705269076
Project: python+ selenium自动化测试练习篇2
'''

# 3.导入模块
from selenium import webdriver

driver = webdriver.Chrome()
driver.maximize_window()
driver.implicitly_wait(6)

driver.get("https://www.baidu.com")
try:
    driver.find_element_by_link_text("新闻")
    print ('test pass: element found by link text')
except Exception as e:
    print ("Exception found", format(e))

driver.quit()

2.3运行结果

运行代码后,控制台打印如下图的结果

总结:凡是看到链接元素上面有文字描述的都可以采取find_element_by_link_text()方法来进行元素定位。这里提一下前面XPath定位中的知识,通过text()这个XPath中的函数也可以达到类似link text定位的目的。

这个“新闻”链接元素的XPath表达式可以这样写://*/div@id='u1'/atext()='新闻'

3. partial link text定位元素

这里我们来介绍如何通过partial link text来定位页面元素。看到这个,有点和前一篇文字link text有点类似。字面意思,确实和link text相类似,partial link text就是选择这个元素的link text中一部分字段。

还是用百度首页输入框下有一个添加首页“把百度设为主页”。

3.1代码实现

3.2参考代码

代码语言:javascript
复制
# coding=utf-8?

# 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2019-11-29
@author: 北京-宏哥   QQ交流群:705269076
Project: python+ selenium自动化测试练习篇2
'''

# 3.导入模块
from selenium import webdriver

driver = webdriver.Chrome()
driver.maximize_window()
driver.implicitly_wait(6)

driver.get("https://www.baidu.com")
try:
    driver.find_element_by_partial_link_text("主页").click()
    print ('test pass: element found by partial link text')
except Exception as e:
    print ("Exception found", format(e))

driver.quit()

3.3运行结果

运行代码后,控制台打印如下图的结果

为了更好的验证是否找到了“把百度添加到首页”这个元素,我在这个地方添加了一个click(),运行代码,可以看到确实点击了这个元素,代表找到了这个元素。选择partial link text的时候,需要选择一个比较唯一的字段,来区分这个元素。

4. class name的值来定位页面元素

有时候,我们在用firepath(不会的请点这里)查看元素的XPath信息,发现没有可以用来定位的id信息,这个时候我们就需要考虑用其他的可用的来定位元素。本文介绍如何通过元素节点中class name的值来定位页面元素。还是以百度首页,搜索输入框定位举例:

XPath截图

4.1 代码实现:

4.2 参考代码:

代码语言:javascript
复制
# coding=utf-8?

# 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2019-11-29
@author: 北京-宏哥   QQ交流群:705269076
Project: python+ selenium自动化测试练习篇2
'''

# 3.导入模块
from selenium import webdriver

driver = webdriver.Chrome()
driver.maximize_window()
driver.implicitly_wait(6)

driver.get("https://www.baidu.com")
try:
    driver.find_element_by_class_name("s_ipt")
    print ('test pass: element found by class name')
except Exception as e:
    print ("Exception found", format(e))

driver.quit()

4.3 运行结果:

运行代码后,控制台打印如下图的结果

参考意见:很多情况下,class利用要比id多,如果class中出现了太长的字符,和可变化的数字,那么请回到用XPath定位方法。

5. name的值来定位元素

这里介绍如何通过节点中name的值来定位这个web元素。还是来看百度首页搜索输入框,通过name的值来定位。

5.1 代码实现:

5.2 参考代码:

代码语言:javascript
复制
# coding=utf-8?

# 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2019-11-29
@author: 北京-宏哥   QQ交流群:705269076
Project: python+ selenium自动化测试练习篇2
'''

# 3.导入模块
from selenium import webdriver

driver = webdriver.Chrome()
driver.maximize_window()
driver.implicitly_wait(6)

driver.get("https://www.baidu.com")
try:
    driver.find_element_by_name("wd") # 这里百度搜索输入框有name = 'wd'这个节点信息
    print ('test pass: element found by name value')
except Exception as e:
    print ("Exception found", format(e))

driver.quit()

5.3 运行结果:

运行代码后,控制台打印如下图的结果

总结:name这个属性不是所有的节点都有,如果有建议采用name的值来定位,就和by_id, by_class一样的效果。

6. 小结

好了,今天的练习就到这里,希望大家好好的练习和理解。

下一篇
举报
领券