Selenium元素定位

Selenium提供8种元素定位的方法

id,name,class name,link text,xpath,css selector,tag name ,partial link text

这八种用python语言表示为

find_element_by_id()
find_element_by_name()
find_element_by_class_name()
find_element_by_tag_name()
find_element_by_link_text()
find_element_by_partial_link_text()
find_element_by_xpath()
find_element_by_css_selector()
Selenium元素定位_第1张图片
这是百度首页的输入框的属性

1、通过class、id、name定位元素

from selenium import webdriver  
browser = webdriver.Chrome()
browser.get("https://www.baidu.com/")
# 通过class定位搜索框
a  = browser.find_element_by_class_name("s_ipt")
# 通过id定位搜索框
b  = browser.find_element_by_id("kw")
# 通过name定位搜索框
c  = browser.find_element_by_name("wd")
print(a)
print(b)
print(c)
browser.close()
>>>



2、通过tag定位元素

HTML是通过 tag 来定位元素的功能的,比如 table是表格,a是超链接 等等,但是一个网页中会有许多 tag,所以一般来说不会通过 tag 来定位元素

3、通过 link text、partial link text定位元素

Selenium元素定位_第2张图片

通过脚本定位到 新闻 这个超链接,并点击

from selenium import webdriver
browser = webdriver.Chrome()
browser.get("https://www.baidu.com/")
link = browser.find_element_by_link_text("新闻").click()

如果链接的字符串太长的话,全部输入影响代码美观也容易出错,这时就可以采用 partial link text,模糊匹配、截取字符串的一部分定位到元素 就可以了

from selenium import webdriver
browser = webdriver.Chrome()
browser.get("https://www.baidu.com/")
link = browser.find_element_by_partial_link_text("闻").click()

4、通过 Xpath 定位元素

XPath定位元素的方法有很多中,这里介绍一种最简单粗暴的:
那就是利用浏览器调试功能,定位到元素所在的那一行右键-->Copy-->Copy XPath

Selenium元素定位_第3张图片

Selenium元素定位_第4张图片

当然这也是一个办法,但是最好还是自己了解到到底应该 怎么用Xpath定位到元素

4、通过 CSS selector 定位元素

与Xpath比较

  • 优点:更高效更准确更易编写
  • 缺点:根据页面文字定位时,没有Xpath直接
    详情请参考:http://www.w3school.com.cn/cssref/css_selectors.asp

你可能感兴趣的:(Selenium元素定位)