selenium安装卸载
安装
pip install selenium
查看
pip show selenium
卸载
pip uninstall selenium
快捷键:
ctrl+alt+space 快速导包
扩展
1.安装指定版本
pip install selenium ==版本号
eg:pip install selenium ==2.48.0
驱动下载地址
谷歌:http://npm.taobao.org/mirrors/chromedriver/87.0.4280.88/
火狐:https://github.com/mozilla/geckodriver/releases
下载对应版本,放在本地,将路径放到环境变量中,即可
Selenium提供了八种定位元素方式
1. id定位
element = driver.find_element_by_id(id)
2.name定位
element = driver.find_element_by_name(name)
3.class_name定位方法
element = driver.find_element_by_class_name(class_name)
4.link_text定位
说明:link_text定位是专门用来定位超链接元素(标签),并且是通过超链接的文本内容来定位元素
。
element = driver.find_element_by_link_text(link_text)
link_text:为超链接的全部文本内容
5.tag_name定位
说明:tag_name定位就是通过标签名来定位;
HTML本质就是由不同的tag组成,每一种标签一般在页面中会存在多个,所以不方便进行精确定位,
一般很少使用
element = driver.find_element_by_tag_name(tag_name)
如果存在多个相同标签,则返回符合条件的第一个标签
如何获取第二个元素?稍后讲解
6.partial_link_text定位
说明:partial_link_text定位是对link_text定位的补充,link_text使用全部文本内容匹配元素,
而partial_link_text可以使用局部来匹配元素,也可以使用全部文本内容匹配元素。
element = driver.find_element_by_partial_link_text(partial_link_text)
partial_link_text:可以传入a标签局部文本-能表达唯一性
7.定位一组元素
find_elements_by_css()
作用:
1). 查找定位所有符合条件的元素
2). 返回的定位元素格式为数组(列表)格式;
说明:
1). 列表数据格式的读取需要指定下标(下标从0开始)
8.Xpath定位元素
1).准备
安装旧版本火狐浏览器
地址:
64位火狐54:http://ftp.mozilla.org/pub/firefox/releases/54.0.1/win64/zh-CN/
32位火狐54:http://ftp.mozilla.org/pub/firefox/releases/54.0.1/win32/zh-CN/
在网上下载firebug和irepath插件即可
在火狐浏览器中将两个组件添加至浏览器即可
2).XPath定位策略(方式)
1. 路径-定位
2. 利用元素属性-定位
3. 属性与逻辑结合-定位
4. 层级与属性结合-定位
3).xpath定位方法
实例代码
from selenium import webdriver
from time import sleep
driver = webdriver.Chrome()
url = r'file:///C:/Users/sgd_user/Desktop/driver/cailiaoeg/%E6%B3%A8%E5%86%8CA.html'
driver.get(url)
#绝对路径xpaths
#driver.find_element_by_xpath('/html/body/form/div/fieldset/p[1]/input').send_keys('123')
#使用层级
#driver.find_element_by_xpath("//p[@id='p1']/input").send_keys('123')
#相对路径xpath
#driver.find_element_by_xpath("//input[@id='passwordA']").send_keys("123")
#逻辑结合
#driver.find_element_by_xpath("//input[@id='passwordA'and @name='passwordA']").send_keys("123")
sleep(3)
driver.quit()
延申
//[text()=“xxx”] 文本内容是xxx的元素
//[contains(@attribute,‘xxx’)] 属性中含有xxx的元素 (移动端定位常用)
eg://*[contains(@id,“p1”)]
//[starts-with(@attribute,‘xxx’)] 属性以xxx开头的元素
eg://[starts-with(@id,“us”)]
9.css定位
#使用css id选择器
driver.find_element_by_css_selector('#userA').send_keys('admin')
#使用css属性选择器
driver.find_element_by_css_selector(“[name='passwordA']").send_keys('123456')
#使用class选择器
driver.find_element_by_css_selector('.telA').send_keys('15601021091')
#使用css元素选择器定位span标签获取文本值
span = driver.find_element_by_css_selector("span").text
print(span)
#使用层级选择器,定位email,输入123@qq.com
driver.find_element_by_css_selector("p>input[id='emailA']").send_keys('123@qq.com')
延申
input[type^=‘p’] type属性以p字母开头的元素
eg:[id^=‘em’]
input[type = ′ d ′ ] t y p e 属 性 以 d 字 母 结 束 的 元 素 [ i d ='d'] type属性以d字母结束的元素 [id =′d