python selenium定位元素方法,python + selenium 练习篇 - 定位元素的方法

1.利用ID定位元素(能直接通过ID来定位的元素比较少)

# coding=utf-8

from selenium import webdriver

driver = webdriver.Chrome()

driver.maximize_window()

url = ("http://www.baidu.com")

driver.get(url)

try:

driver.find_element_by_id("kw")

print('test pass: ID found')

except Exception as e:

print("Exception found",format(e))

driver.quit()

2.利用tag name定位元素(tag name重复的比较多,定位不够精确)

driver.find_element_by_tag_name("form")

3.利用link text定位元素

driver.find_element_by_link_text("新闻")

4.利用partial link text定位元素

driver.find_element_by_pertial_link_text("主页").click()

5.利用class name定位元素

driver.find_element_by_class_name("s_ipt")

6.利用name定位元素(不是所有节点都有这个属性)

driver.find_element_by_name("wd")

7.利用css定位元素

driver.find_element_by_css_selector("#su")

8.利用xpath定位元素

driver.find_element_by_xpath("//*[@id='kw'].send_keys("selenium")

#driver.find_element_by_xpath("//*[@id='kw']/a[text()='新闻']")

#driver.find_element_by_xpath("//*[a[contains(@href,'diannao')]     #contains方法

driver.find_element_by_xpath("//div/h3/a[text()='官网']/../a/em[text()='Selenium']").is_displayed()  #相对路径

Python+Selenium定位元素的方法

Python+Selenium有以下八种定位元素的方法: 1. find_element_by_id() eg: find_element_by_id("kw") 2. find_ ...

Python selenium根据class定位页面元素

在日常的网页源码中,我们基于元素的id去定位是最万无一失的,id在单个页面中是不会重复的.但是实际工作中,很多前端开发人员并未给每个元素都编写id属性.通常一段html代码如下:

Python+Selenium练习篇之1-摘取网页上全部邮箱

前面已经介绍了Python+Selenium基础篇,通过前面几篇文章的介绍和练习,Selenium+Python的webUI自动化测试算是入门了.接下来,我计划写第二个系列:练习篇,通过一些练习,了解 ...

Python+Selenium中级篇之8-Python自定义封装一个简单的Log类《转载》

Python+Selenium中级篇之8-Python自定义封装一个简单的Log类: https://blog.csdn.net/u011541946/article/details/70198676

python去除列表中重复元素的方法

列表中元素位置的索引用的是L.index 本文实例讲述了Python去除列表中重复元素的方法.分享给大家供大家参考.具体如下: 比较容易记忆的是用内置的set 1 2 3 l1 = ['b','c', ...

【Selenium01篇】python+selenium实现Web自动化:搭建环境,Selenium原理,定位元素以及浏览器常规操作!

一.前言 最近问我自动化的人确实有点多,个人突发奇想:想从0开始讲解python+selenium实现Web自动化测试,请关注博客持续更新! 二.话不多说,直接开干,开始搭建自动化测试环境 这里以前在 ...

Python+Selenium练习篇之2-利用ID定位元素

在前面一篇文章,我们介绍了如何摘取页面字段,通过正则进行匹配符合要求的字段.如果感觉有点困难,不能立马理解,没有关系.把字符串摘取放到第一篇,是因为自动化测试脚本,经常要利用字符串操作,字符串切割,查 ...

Python+Selenium练习篇之8-利用css定位元素

前面介绍了,XPath, id , class , link text, partial link text, tag name, name 七大元素定位方法,本文介绍webdriver支持的最后一个 ...

Python+Selenium练习篇之6-利用class name定位元素

有时候,我们在用firepath(不会的请点这里)查看元素的XPath信息,发现没有可以用来定位的id信息,这个时候我们就需要考虑用其他的可用的来定位元素.本文介绍如何通过元素节点中class nam ...

随机推荐

禁用nested loop join里的spool

禁用nested loop join里的spool 转载自: https://blogs.msdn.microsoft.com/psssql/2015/12/15/spool-operator-and ...

自定义button

改变button内部label和imageView的frame - (CGRect)titleRectForContentRect:(CGRect)contentRect - (CGRect)imag ...

Spring+C3P0数据库连接池配置

一.xml文件读取.properties文件连接数据库 1.xml文件中的配置

mybatis分页插件以及懒加载

1.   延迟加载 延迟加载的意义在于,虽然是关联查询,但不是及时将关联的数据查询出来,而且在需要的时候进行查询. 开启延迟加载:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值