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()
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()
>>>
<selenium.webdriver.remote.webelement.WebElement (session="1720d5370aeb03aca930539033559b4c", element="0.4967300544744968-1")>
<selenium.webdriver.remote.webelement.WebElement (session="1720d5370aeb03aca930539033559b4c", element="0.4967300544744968-1")>
<selenium.webdriver.remote.webelement.WebElement (session="1720d5370aeb03aca930539033559b4c", element="0.4967300544744968-1")>
2、通过tag定位元素
HTML是通过 tag 来定位元素的功能的,比如 table是表格,a是超链接 等等,但是一个网页中会有许多 tag,所以一般来说不会通过 tag 来定位元素
3、通过 link text、partial link text定位元素
通过脚本定位到 新闻 这个超链接,并点击
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
当然这也是一个办法,但是最好还是自己了解到到底应该怎么用Xpath定位到元素
4、通过 CSS selector 定位元素
与Xpath比较
- 优点:更高效更准确更易编写
- 缺点:根据页面文字定位时,没有Xpath直接
详情请参考:http://www.w3school.com.cn/cssref/css_selectors.asp