Selenium是一个浏览器自动化操做框架。selenium主要由三种工具组成。css
WebDriver 是一种用于 Web 应用程序的自动测试工具,提供了一套友好的 API,方便咱们进行操做。html
chromedriver要与本地浏览器版本一致python
下载地址(极客时间)
http://npm.taobao.org/mirrors/chromedriver/web
mac中将chromedriver解压后放在usr/local/bin下
windows将 Chrome 浏览器目录添加到系统的环境变量 Path中chrome
或者在使用时直接指定chromedriver路径npm
chrome_driver = "C:\Users\cheny\AppData\Local\Google\Chrome\Application\chromedriver.exe" driver = webdriver.Chrome(executable_path=chrome_driver)
from selenium import webdriver import time wd = webdriver.Chrome() wd.get("https://www.baidu.com") # 打开百度浏览器 wd.find_element_by_id("kw").send_keys("selenium") # 定位输入框并输入关键字 wd.find_element_by_id("su").click() #点击[百度一下]搜索 time.sleep(3) #等待3秒 wd.quit() #关闭浏览器
from selenium import webdriver driver = webdriver.Chrome() #属性: driver.current_url #用于得到当前页面的URL driver.title #用于获取当前页面的标题 driver.page_source #用于获取页面html源代码 driver.port #用于获取浏览器的端口 driver.capabilities['version'] #打印浏览器version的值 #浏览器: driver.get(url) #浏览器加载url driver.back() #浏览器后退 driver.forward() #浏览器前进 driver.refresh() #浏览器刷新(点击刷新按钮) driver.set_page_load_timeout(5) #设置页面加载时间,若是超时会跑异常 driver.implicitly_wait(秒) #隐式等待,经过必定的时长等待页面上某一元素加载完成。 #若提早定位到元素,则继续执行。等待10s若超过期间未加载出,则抛出NoSuchElementException异常。 #执行js: driver.execute_script(js) #调用js #互动到页面下方的两种方法(有的页面滑到底部会有加载更多) js = "var q=document.documentElement.scrollTop=9000" #1 js = "window.scrollTo(0,document.body.scrollHeight)" #2 wd.execute_script(js)
#窗口: driver.current_window_handle #用于获取当前窗口句柄 driver.window_handles #用于获取全部窗口句柄 driver.maximize_window() #将浏览器最大化显示 driver.set_window_size(480, 800) #设置浏览器宽480、高800显示 driver.get_window_size() #获取当前窗口的长和宽 driver.get_window_position() #获取当前窗口坐标 driver.set_window_position(300,200) #设置当前窗口坐标 driver.get_screenshot_as_file(filename) #截取当前窗口 #实例:driver.get_screenshot_as_file('D:/selenium/image/baidu.jpg') driver.close() #关闭当前窗口,或最后打开的窗口 driver.quit() #关闭全部关联窗口,而且安全关闭session #窗口切换: driver.switch_to_frame(id或name属性值)#切换到新表单(同一窗口)。若无id或属性值,可先经过xpath定位到iframe,再将值传给switch_to_frame() driver.switch_to.parent_content()#跳出当前一级表单。该方法默认对应于离它最近的switch_to.frame()方法 driver.switch_to.default_content() #跳回最外层的页面 driver.switch_to_window(窗口句柄) #切换到新窗口 driver.switch_to.window(窗口句柄) #切换到新窗口 #弹框切换: driver.switch_to_alert() #警告框处理。处理JavaScript所生成的alert,confirm,prompt driver.switch_to.alert() #警告框处理
driver.get_cookies() #获取当前会话全部cookie信息 driver.get_cookie(cookie_name) #返回字典的key为“cookie_name”的cookie信息。 #实例:driver.get_cookie("NET_SessionId") driver.add_cookie(cookie_dict) #添加cookie。“cookie_dict”指字典对象,必须有name和value值 driver.delete_cookie(name,optionsString) #删除cookie信息 driver.delete_all_cookies() #删除全部cookie信息
''' 能经过id和name的,尽可能不要用xpath和css Id定位 惟一属性定位 组合定位 先找到相邻的元素 绝对路径 ''' diver.find_element("xpath",".//a//span") #利于封装 driver.find_element_by_id() driver.find_element_by_name() driver.find_element_by_class_name() driver.find_element_by_tag_name() driver.find_element_by_link_text() driver.find_element_by_partial_link_text() #模糊查询 driver.find_element_by_xpath() driver.find_element_by_css_selector() #css选择定位器
# 属性: element.size #获取元素的尺寸。 element.text #获取元素的文本。 element.tag_name #获取标签名称 element.clear() #用于清除输入框的默认内容 element.send_keys("xx") #用于在一个输入框里输入 xx 内容 element.click() #用于单击一个按钮 element.submit() #提交表单 element.size #返回元素的尺寸 element.text #获取元素文本 element.get_attribute('value') #返回元素的属性值,能够是id、name、type或元素拥有的其它任意属性 #若是是input的,能够经过获取value值得到当前输入的值 element.is_displayed () #返回元素的结果是否可见,返回结果为True或False element.is_enabled() #判断元素是否可用 element.is_selected() #返回单选按钮、复选框元素结果是否被选中(True 或 False) element.value_of_css_property(height) #获取元素css样式属性
#引入ActionChains类 from selenium.webdriver.common.action_chains import ActionChains mouse =driver.find_element_by_xpath("xx") #定位鼠标元素 #对定位到的元素执行鼠标操做 ActionChains(driver).context_click(mouse).perform() #鼠标右键操做 ActionChains(driver).double_click(mouse).perform() #鼠标双击操做 ActionChains(driver).move_to_element(mouse).perform() #鼠标移动到上面的操做 ActionChains(driver).click_and_hold(mouse).perform() #鼠标左键按下的操做 ActionChains(driver).release(mouse).perform() #鼠标释放 #鼠标拖拽 element = driver.find_element_by_name("xxx") #定位元素的原位置 target = driver.find_element_by_name("xxx") #定位元素要移动到的目标位置 ActionChains(driver).drag_and_drop(element, target).perform() #执行元素的移动操做
#引入Keys类包 from selenium.webdriver.common.keys import Keys element.send_keys(Keys.BACK_SPACE) #删除键(BackSpace) element.send_keys(Keys.SPACE) #空格键(Space) element.send_keys(Keys.TAB) #制表键(Tab) element.send_keys(Keys.ESCAPE) #回退键(Esc) element.send_keys(Keys.ENTER) #回车键(Enter) element.send_keys(Keys.CONTROL,'a') #全选(Ctrl+A) element.send_keys(Keys.CONTROL,'c') #复制(Ctrl+C) element.send_keys(Keys.CONTROL,'x') #剪切(Ctrl+X) element.send_keys(Keys.CONTROL,'v') #粘贴(Ctrl+V) element.send_keys(Keys.F12) #键盘F12 #输入空格键+“python” element.send_keys(Keys.SPACE) element.send_keys("python")