python+selenium——详解介绍Selenium常用API的使用--python语言(完整版)
Posted xiaobaibailongma
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python+selenium——详解介绍Selenium常用API的使用--python语言(完整版)相关的知识,希望对你有一定的参考价值。
参考:http://www.51testing.com/html/03/n-3725703-2.html
from selenium import webdriver
driver = webdriver.Firefox() # 指定浏览器驱动 #对象实例化
--------------------------------------------------------------------------
url1=‘https://www.baidu.com‘ #需要打开的网址
driver.get(url1) #driver.get("https://www.baidu.com")
===========================================================================================================================元素定位
页面元素定位,8种常用定位方法:
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()
============================================================================================================================
from selenium.webdriver.common.by import By #需要引入包
driver.find_element(By.ID,"kw")
driver.
find_element(By.NAME,"wd")
driver.find_element(By.CLASS_NAME,"bg")
driver.find_element(By.TAG_NAME,"input")
driver.find_element(By.LINK_TEXT,"新闻")
driver.find_element(By.XPATH,"//*[@id=‘idname‘]")
driver.find_element(By.CSS_SELECTOR,"span>input#su")
============================================================================================================================
定位一组元素,WebDriver 还提供了与之对应的 8 种定位方法用于定位一组元素:
driver.find_elements_by_id()
driver.find_elements_by_name()
driver.find_elements_by_class_name()
driver.find_elements_by_tag_name()
driver.find_elements_by_link_text()
driver.find_elements_by_partial_link_text()
driver.find_elements_by_xpath()
driver.find_elements_by_css_selector()
定位一组对象的方法与定位单个对象的方法类似,唯一的区别是在单词 element 后面多了一个 s 表示复数。
定位一组对象一般用于以下场景:批量操作对象,比如将页面所有的复选框都被勾选。
先获取一组对象,再在这组对象中过滤出需要具体定位的一些对象。
from selenium import webdriver
from time import sleep
from selenium.webdriver.common.by import By
driver = webdriver.Firefox()
driver.get("http://www.baidu.com")
sleep(5)
x = driver.find_elements(By.CLASS_NAME,"mnav")
for fac in x:
print(fac.text)
driver.close()
-----------------------------------------------------------
抗击肺炎
新闻
hao123
地图
视频
贴吧
学术
===========================================================================================================================
webelement对象是selenium中所有元素的父类,也就是webelement对象拥有的方法,其它元素对象都会有;
只是不同的对象在调用特定方法时,效果是不一样的,即:某些方法只是针对特定元素类型有效,而对其它类型无效。
(1)、clear:清空文本框中的文本,仅仅对有文本输入特性的元素有效;例如:文本框、多行文本框等;
(2)、click:单击元素,可以通过该方法,让元素获取焦点;
(3)、find_element系列:查找子元素的方法,同浏览器的find_element系列方法相同;
(4)、get_attribute:获取当前元素的特定属性值,如 name、style等;
(5)、id:表示当前元素在selenium中的唯一标识;
(6)、is_displayed:当前元素是否可见;
(7)、is_enabled:当前元素是否可用;
(8)、is_selected:当前元素是否被选中,通常在checkbox、radiobox、select option等元素上;
(9)、location:返回当前元素的左上角坐标X、Y的位置,即在当前页面中的绝对位置坐标;
(10)、location_once_scrolled_into_view:返回当前元素第一次滚动到可视区域时的左上角坐标X、Y的位置,
使用此方法可以把不在可视区域的元素,滚动到可视区域;
(11)、parent:返回WebDriver对象;
(12)、rect:返回当前元素左上角坐标X、Y值,以及该元素的宽和高,即该元素的显示区域;
(13)、send_keys:向当前元素发送字符串内容,仅仅对可输入web元素有效,如文本框、文本区域等;
(14)、size:获取当前元素的宽和高;
(15)、submit:提交当前元素所在的form表单,相当于单击所在form表单内的submit;
(16)、tag_name:获取当前元素的tag name内容,如文本框的值为input;
(17)、text:获取当前元素的inneerText值,即元素开始标签和结束标签之间的文本内容;
(18)、value_of_css_property:获取当前元素的css属性,如获取color的属性值;
driver = webdriver.Firefox()
driver.get("http://www.baidu.com")
driver.find_element_by_id("kw").clear() #文本框清空
driver.find_element_by_id("kw").send_keys() #文本框输入
driver.find_element_by_id("su").click() #点击
driver.find_element_by_id("su").submit() #提交
----------------------------------------------------------------------------------------------------------------------------------------------------
# http://www.baidu.com 首页html源代码
#
# 输入框: <input id="kw" name="wd" class="s_ipt" value="" maxlength="255" autocomplete="off">
#
# 确定按钮: <input type="submit" id="su" value="百度一下" class="bg s_btn">
print(driver.find_element_by_id(‘kw‘).tag_name) # input
print(driver.find_element_by_id(‘kw‘).get_attribute(‘name‘)) # wd
print(driver.find_element_by_id(‘kw‘).get_attribute(‘id‘)) # kw
print(driver.find_element_by_id(‘kw‘).get_attribute(‘class‘)) # s_ipt
print(driver.find_element_by_id(‘kw‘).get_attribute(‘value‘)) # 中国
print(driver.find_element_by_id(‘kw‘).parent) # <selenium.webdriver.firefox.webdriver.WebDriver (session="ec5c73e4-93ce-4e0a-b74a-26b49b175fda")>
-------------------------------------------------------------------------------------------------------------------------------------------------------
print(driver.find_element_by_id(‘kw‘).location) #{‘x‘: 129, ‘y‘: 18}返回当前元素的左上角坐标X、Y的位置,即在当前页面中的绝对位置坐标 #返回X、Y
print(driver.find_element_by_id(‘kw‘).size) #{‘height‘: 22.0, ‘width‘: 494.0} 获取当前元素的宽和高 #返回宽和高
print(driver.find_element_by_id(‘kw‘).rect) #{‘x‘: 129.0, ‘y‘: 18.0, ‘width‘: 494.0, ‘height‘: 22.0} 返回当前元素左上角坐标X、Y值,以及该元素的宽和高,
即该元素的显示区域; #返回X、Y,宽和高,即可视区域
print(driver.find_element_by_id(‘kw‘).value_of_css_property(‘color‘)) # rgb(0, 0, 0) #获取当前元素的css属性,如获取color的属性值
===========================================================================================================================键盘引入
from selenium.webdriver.common.keys import Keys #键盘导入类
------------------------------------------------------------------------------
常用的键盘操作:
send_keys(Keys.BACK_SPACE):删除键(BackSpace)
send_keys(Keys.SPACE):空格键(Space)
send_keys(Keys.TAB):制表键(TAB)
send_keys(Keys.ESCAPE):回退键(ESCAPE)
send_keys(Keys.ENTER):回车键(ENTER)
send_keys(Keys.CONTROL,‘a‘):全选(Ctrl+A)
send_keys(Keys.CONTROL,‘c‘):复制(Ctrl+C)
send_keys(Keys.CONTROL,‘x‘):剪切(Ctrl+X)
send_keys(Keys.CONTROL,‘v‘):粘贴(Ctrl+V)
send_keys(Keys.F1):键盘F1
.....
send_keys(Keys.F12):键盘F12
-------------------------------------------------------------------------------------------------------------------------
from selenium import webdriver
from selenium.webdriver.common.keys import Keys #键盘导入类
from time import sleep
driver = webdriver.Firefox() # 指定和打开浏览器
driver.get(‘http://www.baidu.com‘)
driver.find_element_by_id(‘kw‘).send_keys(‘seleniumm‘) #在输入框输入内容
sleep(4)
driver.find_element_by_id(‘kw‘).send_keys(Keys.BACK_SPACE) #删除键 #删除多输入的一个字
sleep(4)
driver.find_element_by_id(‘kw‘).click()
driver.find_element_by_id(‘kw‘).send_keys(Keys.SPACE) # 输入空格键
sleep(4)
driver.find_element_by_id(‘kw‘).send_keys(Keys.CONTROL, ‘a‘) #输入Control+a模拟全选
driver.find_element_by_id(‘kw‘).send_keys(Keys.CONTROL, ‘c‘) #输入Control+c模拟复制
driver.find_element_by_id(‘kw‘).click() #单击之后鼠标焦点就在文字后面了,不然还在文字上,粘贴就会直接覆盖文字
driver.find_element_by_id(‘kw‘).send_keys(Keys.CONTROL, ‘v‘) #输入Control+v模拟粘贴
sleep(8)
driver.find_element_by_id(‘kw‘).send_keys(Keys.ENTER) #回车键
sleep(5)
driver.close()
===========================================================================================================================鼠标引入
from selenium.webdriver.common.action_chains import ActionChains #导入鼠标相关的包
--------------------------------------------------------------------------------------------
submit = driver.find_element_by_id(‘kw‘) #首先创建对象
ActionChains(driver).click(submit).perform() #左键
ActionChains(driver).context_click(submit).perform() #右键
ActionChains(driver).double_click(submit).perform() #双击
----------------------------------------------------------------------------------------------------------------------
ActionChains(driver).drag_and_drop_by_offset(submit,10,10).perform() #拖放到指定坐标位置
ActionChains(driver).drag_and_drop(submit,target).perform() #拖放到目标元素位置 #target也是创建的一个对象
--------------------------------------------------------------------------------------------
ActionChains(driver).move_by_offset(10,10).perform() #鼠标在指定坐标悬停
ActionChains(driver).move_to_element(submit).perform() #鼠标在指定元素悬停
ActionChains(driver).move_to_element_with_offset(submit,5,5).perform() #鼠标在指定元素的指定坐标悬停
---------------------------------------------------------------------------------------------------------
ActionChains(driver).click_and_hold(submit).perform() #鼠标左键元素并保持
ActionChains(driver).context_click(submit).perform() #鼠标右键元素并保持
-----------------------------------------------------------------------------------------------
ActionChains(driver).key_down(Keys.CONTROL).send_keys(‘a‘).key_up(Keys.CONTROL).perform() #ctrl+a全选组合键
ActionChains(driver).key_down(Keys.CONTROL).send_keys(‘c‘).key_up(Keys.CONTROL).perform() #ctrl+c 复制组合键
ActionChains(driver).key_down(Keys.CONTROL).send_keys(‘v‘).key_up(Keys.CONTROL).perform() #ctrl+v 粘贴组合键
================================================================================================
from selenium import webdriver
from selenium.webdriver.common.keys import Keys #导入键盘相关的包
from selenium.webdriver.common.action_chains import ActionChains #导入鼠标相关的包
from time import sleep
driver = webdriver.Firefox() # 指定和打开浏览器
driver.get(‘http://www.baidu.com‘)
#driver.find_element_by_id(‘kw‘).send_keys(‘中国‘)
#sleep(4)
#submit = driver.find_element_by_id(‘su‘)
#ActionChains(driver).click(submit).perform() #对搜索按钮 鼠标左点击
#sleep(4)
#------------------------------------------------------------------------------------------
#submit = driver.find_element_by_link_text("设置")
#ActionChains(driver).move_to_element(submit).perform() #鼠标悬停在上面
#sleep(5)
#driver.find_element_by_class_name("setpref").click() # 打开搜索设置
#sleep(2)
#-----------------------------------------------------------------------------------------
location01 = driver.find_element_by_link_text(‘新闻‘) # 鼠标拖动事件
sleep(7)
location02 = driver.find_element_by_link_text(‘更多产品‘)
ActionChains(driver).drag_and_drop(location01, location02).perform()
sleep(8)
driver.close()
=============================================================================================
from selenium import webdriver
from selenium.webdriver.common.keys import Keys #导入键盘相关的包
from selenium.webdriver.common.action_chains import ActionChains #导入鼠标相关的包
from time import sleep
driver = webdriver.Firefox() # 指定和打开浏览器
driver.get(‘http://www.baidu.com‘)
driver.find_element_by_id(‘kw‘).send_keys(‘中国‘)
sleep(4)
driver.find_element_by_id(‘kw‘).click()
ActionChains(driver).key_down(Keys.CONTROL).send_keys(‘a‘).key_up(Keys.CONTROL).perform() #全选
sleep(4)
ActionChains(driver).key_down(Keys.CONTROL).send_keys(‘c‘).key_up(Keys.CONTROL).perform() #复制、拷贝
sleep(4)
driver.find_element_by_id(‘kw‘).click()
ActionChains(driver).key_down(Keys.CONTROL).send_keys(‘v‘).key_up(Keys.CONTROL).perform() #粘贴
sleep(8)
driver.close()
===========================================================================================================================时间引入
from time import sleep
sleep(15)
===========================================================================================================================driver常用方法
from selenium import webdriver
driver = webdriver.Firefox() # 指定浏览器驱动 #对象实例化
调用说明
driver.属性值
变量说明:
1.driver.current_url:用于获得当前页面的URL
2.driver.title:用于获取当前页面的标题
3.driver.page_source:用于获取页面html源代码
4.driver.current_window_handle:用于获取当前窗口句柄
5.driver.window_handles:用于获取所有窗口句柄
函数说明:
1.driver.find_element*():定位元素,
2.driver.get(url):浏览器加载url。 实例:driver.get("http//:www.baidu.com")
3.driver.forward():浏览器向前(点击向前按钮)。
4.driver.back():浏览器向后(点击向后按钮)。
5.driver.refresh():浏览器刷新(点击刷新按钮)。
6.driver.close():关闭当前窗口,或最后打开的窗口。
7.driver.quit():关闭所有关联窗口,并且安全关闭session。
8.driver.maximize_window():最大化浏览器窗口。
9.driver.set_window_size(宽,高):设置浏览器窗口大小。 driver.set_window_size(400,200) #设置浏览器的宽度和高度 {‘width‘: 1382, ‘height‘: 744}
10.driver.get_window_size():获取当前窗口的长和宽。
11.driver.set_window_position(X,Y) #设置浏览器左上角坐标的X,Y值 driver.set_window_position(100,200) {‘x‘: -8, ‘y‘: -8}
12.driver.get_window_position():获取当前窗口坐标。
13.driver.get_screenshot_as_file(filename):截取当前窗口。
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++切换窗口
14.driver.current_window_handle #获取当前窗口句柄
15.driver.window_handles #用于获取所有窗口句柄
--------------------------------------------------------------------------------
suoyou = driver.window_handles # 用于获取所有窗口句柄
16.driver.switch_to.window(suoyou[0]) #切换到第一个句柄
driver.switch_to.window(suoyou[1]) #切换到第二个句柄
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++切换frame
17.driver.switch_to.frame() #切换frame
18.driver.switch_to.default_content() #切换到主页面 #从frame中切回主文档
19.driver.switch_to.parent_frame() #这是switch_to中独有的方法,可以切换到上一层的frame,对于层层嵌套的frame很有用
#driver.switch_to.frame(driver.find_elements_by_tag_name("iframe")[0]) #复数,定位一组iframe的第一个
driver.switch_to.frame(driver.find_element_by_tag_name("iframe")) #因为只有一个iframe,这个也可以用
element = driver.switch_to.active_element 定位到当前聚焦的元素上
ele_box = driver.switch_to.active_element # 通过定位输当前焦点元素,并再次输入数据
ele_box.send_keys("12345sdfgh")
driver.switch_to.frame(‘frame_name‘) #name来点位
driver.switch_to.frame(1) #id来定位
driver.switch_to.frame(driver.find_elements_by_tag_name("iframe")[0]) #用webelement对象来定位,先获取对象
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++alert弹出框
from selenium.webdriver.common.alert import Alert
driver.find_element_by_id(‘alert_button‘).click() #点击触发弹出框alert
alt = Alert(driver)
alt.accept() : 等同于单击“确认”或者“OK”
alt.dismiss() : 等同于单击“取消”或者“Cancel”
alt.send_keys() : 发送文本,针对有提交需求的prompt框
alt.text() : 获取alert文本的内容
alt.authenticate(username,password) : 验证,针对需要身份验证的alert
————————————————————————————————————————————————————
首先使用switch_to.alert()方法进行定位,然后可以使用下面的操作
text:返回alert、confirm、prompt中的文字信息;
accept():接受现有警告框;
dismiss():解散现有警告框;
send_keys():在警告框中输入文本(如果可以输入的话);
20.driver.switch_to.alert.text #获取alert文本框里面的文字
21.driver.switch_to.alert.dismiss() #点击取消按钮
22.driver.switch_to.alert.accept() #点击确定按钮
23.driver.switch_to.alert.send_keys() #在警告框中输入文本(如果可以输入的话)
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++调用js语句
有些浏览器的页面操作,不能依靠WebDriver提供的API来操作,需要借助javascript脚本。
webdriver提供了execute_script()方法来执行JavaScript代码。
24.driver.execute_script(js) #调用/执行js语句的方法。
js = ‘window.scrollTo(100,400);‘ #设置浏览器窗口滚动条的水牌位置和垂直位置
========================================================================================================================================cookie
WebDriver提供了操作Cookie的相关方法,可以读取、添加和删除cookie信息。
WebDriver操作cookie的方法:
25.driver.get_cookies(): 获得所有cookie信息。
26.driver.get_cookie(name): 返回字典的key为“name”的cookie信息。
27.driver.add_cookie(cookie_dict) : 添加cookie。“cookie_dict”指字典对象,必须有name 和value 值。
28.driver.delete_cookie(name,optionsString):删除cookie信息。“name”是要删除的cookie的名称,“optionsString”是该cookie的选项,目前支持的选项包括“路径”,“域”。
29.driver.delete_all_cookies(): 删除所有cookie信息。
======================================================================================================================================
from selenium import webdriver
from time import sleep
driver = webdriver.Firefox() # 指定和打开浏览器
url1=‘http://www.baidu.com‘
print(‘==============================================================================1‘)
driver.delete_all_cookies() #先删除所有cookie
print(driver.get_cookies()) #打印所有cookie
print(‘==============================================================================2‘)
driver.get(url1) #打开第一个网址 #也可以写成:driver.get(‘http://www.baidu.com‘)
sleep(5)
print(driver.get_cookies()) #打印获取到的所有cookie
print(‘==============================================================================3‘)
driver.add_cookie({‘name‘:‘kw‘,‘value‘:‘selenium‘}) #添加一个name为kw,内容为selenium的cookie
print(driver.get_cookie(‘kw‘)) #获取名为kw的cookie
print(driver.get_cookie(‘PSTM‘))
print(‘==============================================================================4‘)
print(driver.get_cookies()) #打印获取到的所有cookie
print(‘==============================================================================5‘)
driver.delete_cookie(‘kw‘) #删除名为kw的cookie
print(driver.get_cookies()) #打印获取到的所有cookie
print(‘==============================================================================6‘)
driver.delete_all_cookies() #删除所有cookie
print(driver.get_cookies()) #打印获取到的所有cookie
print(‘==============================================================================7‘)
print(driver.session_id)
driver.quit() #关闭浏览器 或者:driver.close()
=============================================================================================================================================
=============================================================================================================================================
=============================================================================================================================================
=============================================================================================================================================
注意:新建文件夹这个目录已经存在的前提下:
driver.get_screenshot_as_file(‘C:\Users\del\Desktop\新建文件夹\‘+ picture_time +‘.png‘) #保存于桌面已经存在的新建文件夹里:2020-02-15-19-18-38.png
driver.get_screenshot_as_file(‘C:\Users\del\Desktop\新建文件夹\‘+ picture_time2 +‘.png‘) #日期作为文件名:2020-02-15.png
driver.get_screenshot_as_file(‘C:\Users\del\Desktop\新建文件夹\‘+ picture_time3 +‘.png‘) #时分秒作为文件名:19-18-38.png
============================================================================================================================================================
格式化时间:
import time
picture_time = time.strftime("%Y-%m-%d-%H-%M-%S", time.localtime(time.time()))
print(picture_time) # 2020-02-15-19-18-38
#--------------------------------------------------------------------------------
picture_time2 = time.strftime("%Y-%m-%d", time.localtime(time.time()))
print(picture_time2) # 2020-02-15
#--------------------------------------------------------------------------------
picture_time3 = time.strftime("%H-%M-%S", time.localtime(time.time()))
print(picture_time3) # 19-18-38
=======================================================================================================================================================
以上是关于python+selenium——详解介绍Selenium常用API的使用--python语言(完整版)的主要内容,如果未能解决你的问题,请参考以下文章
Selenium+Python调Chrome浏览器时报Traceback (most recent call last): File "C:/Users/EDZ/Desktop/sele
Python + Selenium + AutoIt 模拟键盘实现另存为上传下载操作详解