Python Selenium 常用方法总结
2020-12-13 15:19
标签:system 输入 tab页 exception 一个 lam view choice nta 1.获取当前页面的Url 方法:current_url 2.获取元素坐标 3.表单的提交 4.获取CSS的属性值 5.获取元素的属性值 6.判断元素是否被选中 7.返回元素的大小 8.判断元素是否显示 9.判断元素是否被使用 10.获取元素的文本值 11.元素赋值 12.返回元素的tagName 13.删除浏览器所有的cookies 14.删除指定的cookie 15.关闭浏览器 16.关闭浏览器并且退出驱动程序 17.返回上一页 18.清空输入框 19.浏览器窗口最大化 20.查看浏览器的名字 21.返回当前会话中的cookies 22.根据cookie name 查找映射Value值 23.截取当前页面 24.获取当前窗口的坐标 25.获取当前窗口的长和宽 ActionChains类鼠标操作的常用方法: 引入ActionChains类:from selenium.webdriver.common.action_chains import ActionChains 26.右击 27.双击 28:鼠标拖放 29:鼠标悬停在一个元素上(hover) 30:按下鼠标左键在一个元素上 键盘事件: 引入Keys类包:from selenium.webdriver.common.keys import Keys 32:输入空格 33:ctrl + a 34:回车代替点击 35:制表键(Tab) 36:回退键(Esc) 等待时间 导入 WebDriverWait 包 37:固定等待时间 38:等待一个元素被发现,或一个命令完成,超出了设置时间则抛出异常智能等待。 39:在设置时间内,默认每隔一段时间检测一次当前页面元素是否存在,如果超过设置时间检测不到则抛出异常 #WebDriverWait(driver, timeout, poll_frequency=0.5, ignored_exceptions=None) 调用该方法提供的驱动程序作为一个参数,直到返回值为False。 # 实例: 判断某个元素是否可见并且是enable的,这样才clickable WebDriverWait(dr,15,1).until(EC.element_to_be_clickable((By.ID,"EmployeeListMenu")),"Not Find element") 40:选择当前页面上所有tag 41:从中过滤出type为checkbox的元素,并勾选上 42:使用CSS定位选择所有type为checkbox的元素,并勾选上 43:把最后一个checkbox的勾去掉,pop()方法空参数时,默认移除list中的最后一个元素。 切换活动对象 44:切换浏览器handle 45:返回上一级表单 46:返回最外层表单 47:切换到指定frame中 48:获取当前page的title 49:焦点切换到弹窗。 50:前进 51:刷新页面 52: 通过下级定位上级 53: 根据文字定位: 54:find_element_by_css_selector()的两种方法: 方式一:后代或平级关系来选择元素 : *[style] 选择所有有stype属性的元素 55:自动化测试selenium常用JS代码执行: 5.Python执行js删除HTML元素的属性值 Python Selenium 常用方法总结 标签:system 输入 tab页 exception 一个 lam view choice nta 原文地址:https://www.cnblogs.com/littles11/p/11577489.html
实例:driver.current_url
方法:location
解释:首先查找到你要获取元素的,然后调用location方法
实例:driver.find_element_by_xpath("xpath").location
方法:submit
解释:查找到表单(from)直接调用submit即可
实例:driver.find_element_by_id("form1").submit()
方法:value_of_css_property(css_name)
实例:driver.find_element_by_css_selector("input.btn").value_of_css_property("input.btn")
方法:get_attribute(element_name)
实例:driver.find_element_by_id("kw").get_attribute("kw")
方法:is_selected()
实例:driver.find_element_by_id("form1").is_selected()
方法:size
实例:driver.find_element_by_id("iptPassword").size
返回值:{‘width‘: 250, ‘height‘: 30}
方法:is_displayed()
实例:driver.find_element_by_id("iptPassword").is_displayed()
方法:is_enabled()
实例:driver.find_element_by_id("iptPassword").is_enabled()
方法:text
实例:driver.find_element_by_id("iptUsername").text
方法:send_keys(*values)
实例:driver.find_element_by_id("iptUsername").send_keys(‘admin‘)
方法:tag_name
实例:driver.find_element_by_id("iptUsername").tag_name
方法:delete_all_cookies()
实例:driver.delete_all_cookies()
方法:delete_cookie(name)
实例:deriver.delete_cookie("my_cookie_name")
方法:close()
实例:driver.close()
方法:quit()
实例:driver.quit()
方法:back()
实例:driver.back()
方法:clear()
实例:driver.clear()
方法:maximize_window()
实例:driver.maximize_window()
方法:name
实例:drvier.name
方法:get_cookies()
实例:driver.get_cookies()
方法:driver.get_cookie(cookie_name)
实例:driver.get_cookie("NET_SessionId")
方法:get_screenshot_as_file(filename)
实例:driver.get_screenshot_as_file("D:\\Program Files\\Python27\\NM.bmp")
方法:get_window_position()
实例:driver.get_window_position()
方法:get_window_size()
实例:driver.get_window_size()
方法:context_click()
实例:ActionChains(driver).context_click(driver.find_element_by_id("id")).perform()
方法:double_click()
实例:ActionChains(driver).double_click(driver.find_element_by_name("name")).perform()
方法:drag_and_drop(source, target)
source:鼠标按下的源元素;target:鼠标释放的目标元素
实例:element = driver.find_element_by_name("name")
target = driver.find_element_by_name("name")
ActionChains(driver).drag_and_drop(element, target).perform()
方法:move_to_element()
实例:above = driver.find_element_by_xpath("xpath路径")
ActionChains(driver).move_to_element(above).perform()
方法:click_and_hold()
实例:left = driver.find_element_by_name("name")
ActionChains(driver).click_and_hold(left).perform()
1
31:输入
方法:send_keys()
实例:driver.find_element_by_id("id").send_keys("XXX")
方法:send_keys(Keys.SPACE)
实例:driver.find_element_by_id("id").send_keys(Keys.SPACE)
全选输入框的内容
ctrl + x
剪切输入框的内容
ctrl + v
粘贴到输入框
ctrl + c
复制
方法:send_keys(Keys.CONTROL,‘a‘)
实例:driver.find_element_by_id("id").send_keys(Keys.CONTROL,‘a‘)
方法:send_keys(Keys.ENTER)
实例:driver.find_element_by_id("id").send_keys(Keys.ENTER)
方法:send_keys(Keys.TAB)
实例:driver.find_element_by_id("id").send_keys(Keys.TAB)
方法:send_keys(Keys.ESCAPE)
实例:driver.find_element_by_id("id").send_keys(Keys.ESCAPE)
from selenium.webdriver.support.ui import WebDriverWait
导入 time 包
import time
方法:sleep()
实例:time.sleep(5) # 等待5秒
方法:implicitly_wait()
实例:driver.implicitly_wait(30)
"方法:WebDriverWait()"
#——driver:WebDriver的驱动程序(Ie, Firefox, Chrome或远程)
#——timeout:最长超时时间,默认以秒为单位
#——poll_frequency:休眠时间的间隔(步长)时间,默认为0.5秒
#——ignored_exceptions:超时后的异常信息,默认情况下抛NoSuchElementException异常
实例:
element = WebDriverWait(driver, 10).until(lambda x: x.find_element_by_id("id"))
#一般由unit()或until_not()方法配合使用,同上:
调用该方法提供的驱动程序作为一个参数,直到返回值不为False。
——until(method, message=’’)
——until_not(method, message=’’)
# 还可以与expected_conditions 一起使用
from selenium.webdriver.support import expected_conditions as EC
name为input的元素
inputs = driver.find_elements_by_tag_name(‘input‘)
for input in inputs:
if input.get_attribute(‘type‘) == ‘checkbox‘:
input.click()
checkboxes = driver.find_elements_by_css_selector(‘input[type = checkbox]‘)
for checkbox in checkboxes:
checkbox.click()
driver.find_elements_by_css_selector(‘input[type = checkbox]‘).pop().click()
# 切换不同的tab页
方法:driver.switch_to.window(window_name)
# 备注:从A页跳转到B页,句柄已经切换过去,但是焦点没有切过去,所以需要switch_to.window,把焦点也切过去,才可以在当前页进行操作。
# 切换是思路,获取所有的句柄,因为返回是一个list,而且要切换的对象都是最后一个,可以使用[-1]直接切过去
# 例如:
driver.switch_to.window(driver.window_handles[-1])
方法: driver.switch_to_parent_content()#旧方法
driver.switch_to.parent_content#新方法
方法: driver.switch_to_default_content()#旧方法
driver.switch_to.default_content()#新方法
方法:driver.switch_to.frame(‘xxx‘)
实例:driver.switch_to.frame(‘frame_name‘)
driver.switch_to.frame(index)
driver.switch_to.frame(driver.find_elements_by_tag_name("iframe")[0])
方法:driver.title
实例:driver.title
方法:driver.switch_to_alert()
实例:driver.switch_to_alert()
方法:driver.forward()
方法:driver.refresh()
方法:/..
实例:driver.find_element_by_xpath(‘//span[text()="确认"]/..‘)
1、全部文字
browser.find_element_by_xpath("//*[text()=‘采购管理‘]").click()
2、部分文字
browser.find_element_by_xpath("//*[contains(text(),‘采购‘)]").click()
父元素:
(#)表示通过 id 属性来定位元素
(.)表示通过 class 属性来定位元素
子元素(后代关系)
#choose_car option 含空格的,后面的元素不必是前面元素的直接子元素,只要在父元素的里面
.s_ipt_wr span
#choose_car > option 含>键的, 后面的元素必须是前面元素的直接子元素
.s_ipt_wr > span
ul > ol > li > em 可以是很多级的父子关系
组合型
#food > span , p 选择id 为food的所有span子元素和所有的p(包括非food的子元素)
#food > span , #food > p 选择id为food的所有span子元素和所有p子元素
#food > * 选择id为food的所有子元素
兄弟节点的选择 (平级关系)
#food + div 只选择id为food紧跟后面的div
#food ~div 选择id为food后面的div或div们,只需要在id的后面,不需要紧跟
方法二:根据元素的属性及属性值来选择元素 :
p[spec=len2] 选择spec属性值只等于len2的p元素
yp[spec=‘len2 len3‘ ] 选择spec属性值只等于len2 len3的p元素 有空的值一定要加引号
p[spec*=‘len2‘] 选择spec属性值包含len2的p元素
p[spec^=‘len2‘] 选择spec属性值以len2开头的p元素
p[spec&=‘len2‘] 选择spec属性值以len2结尾的p元素
p[class=special][name=p1] 选择class值等于special,并且name值等于p1的p元素
p:nth-child(1) 选择第一个p元素
p:nth-last-child(1) 选择倒数第一个p元素(要保证最后一个元素是p)
1.Web界面的滑动
#coding:utf-8
from selenium import webdriver
import time
d = webdriver.Firefox()
d.implicitly_wait(10)
d.maximize_window()
d.get(r‘https://www.tmall.com/‘)
time.sleep(10)
# 用JS获取HTML元素焦点,滚动条就自动滑动到焦点所在位置
# .mui-mbar-tab.mui-mbar-tab-cart.mui-mbar-tab-cart-nologin>div:nth-child(2)
# 查找class属性值为"mui-mbar-tab mui-mbar-tab-cart mui-mbar-tab-cart-nologin"的元素下的第二个div元素
ele =d.find_element_by_css_selector(‘.mui-mbar-tab.mui-mbar-tab-cart.mui-mbar-tab-cart-nologin>div:nth-child(2)‘)
#print ele.text
# 获取一个焦点
js = "arguments[0].scrollIntoView();"
# 获取ele元素所在的位置焦点,滚动条会自动的滑动到获取的焦点位置
d.execute_script(js,ele)
实例:
# 下拉框有多个元素时,将滚动条滚动到要点击的元素位置
providerDepartment = random.choice(providerDepartmentlis) #随机选择一个候选项
self.execute_script("arguments[0].scrollIntoView();", providerDepartment) #滚动到选中候选位置
providerDepartment.click() #选候选项
2.js来拖动滚动条滚动到具体位置
js_="window.scrollTo(400,700);"
driver.execute_script(js_)
3.针对js 非div 元素的 alert 弹出事件 可以用:
from selenium.webdriver import ActionChains
alert = driver.switch_to_alert()
#模拟键盘Enter 键
ActionChains(driver).send_keys(Keys.ENTER).perform()
4.用来选择日期控件,输入框
js="$(‘#SystemDate‘).val(‘2017-07-21‘);"
driver.execute_script(js
#删除属性值:document.getElementById(‘promote_start_date‘).removeAttribute(‘readonly‘)
#添加/修改属性值:document.getElementById("p1").readonly=false
#JS定位元素的方法:document.getElementById/getElementByName/getElementByClassName/getElementByTagName
删除只读属性并输入日期实例:
js="document.getElementById(‘promote_start_date‘).removeAttribute(‘readonly‘)"
driver.execute_script(js)
driver.find_element_by_id(‘promote_start_date‘).clear()
#填写日期 promote_start_date为日期控件的id
driver.find_element_by_id(‘promote_start_date‘).send_keys(‘1997-07-07‘)
下一篇:Component MSWINSCK.OCX' or one of its dependencies not correctly registered: a file is missi