id和name定位元素
这两种方式是比较见的元素定位方式,但是有一定缺陷,如:有的标签里不会有id和name这两个属性,有的id是动态的,这时用id定位代码就可能报错;但是好处也不言而喻,就是代码会很清晰;我在能使用这两种方式定位时,会优先使用;
id定位练习:
from selenium import webdriver #导入selenium
web = webdriver.Chrome() #打开Chrome浏览器
web.get("https://www.baidu.com") #跳转百度首页
web.find_element_by_id("kw").send_keys("id定位") #定位百度搜索框并输入“id定位”
这样就成功通过id定位到百度的搜素框,这其中send_keys需要解释一下,这个方法是在输入框内输入内容;
name定位练习:
web.find_element_by_name("wd").send_keys("name定位")
这里得到的结果和id定位是相同的,因为都是定位的搜索框,只是输入的内容不同;
接下来是tag name和class name定位
tag name是通过标签名字定位:
web.find_element_by_tag_name("input").send_keys("tag name定位")
class name定位
web.find_element_by_class_name("s_ipt").send_keys("class name 定位")
CSS选择器定位和xpath定位
这两种定位方式是比较常用的方式,也适合大部分场景;CSS是一种语言,它被用来描述 HTML 和 XML 文档的表现;CSS 使用选择器来为页面元素绑定属性;xpath是通过路径来进行定位;日后会编辑css和xpath的相关文章;在此不多做赘述;
css选择器定位:
web.find_element_by_css_selector("#kw").send.keys("css选择器定位")
这是的参数中的# 是id属性的意思;
xpath定位:
web.find_element_xpath('//*[@id="kw"]').send.keys("xpath定位")
这里不解释怎么理解xpath路径的含义,需要说明的是因为参数中是有双引号的,所以要注意一下要用单引号来传参;
最后还有一种定位定位方式就是link,文本定位,主要用于的场景是文本超链接
web.find_element_link_text("贴吧").click()