python+selenium的WebElement对象操作
webelement对象操作
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的属性值;
=======================================================================================================
from selenium import webdriver
from time import sleep driver = webdriver.Firefox() # 指定和打开浏览器
url1='http://www.baidu.com'
driver.get(url1) #打开第一个网址 #也可以写成:driver.get('http://www.baidu.com')
sleep(5) driver.find_element_by_id('kw').send_keys('中国') #输入中国 print(driver.find_element_by_id('kw').is_displayed()) #TRUE #是否可见 print(driver.find_element_by_id('kw').is_enabled()) #TRUE #当前元素是否可用 print(driver.find_element_by_id('kw').location) #{'x': 129, 'y': 18} #返回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,宽和高,即可视区域 # 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').value_of_css_property('color')) # rgb(0, 0, 0) #获取当前元素的css属性,如获取color的属性值 driver.quit()
python+selenium的WebElement对象操作的更多相关文章
- python+selenium下拉列表option对象操作方法一
参考官方文档:https://selenium.dev/selenium/docs/api/py/webdriver_support/selenium.webdriver.support.select ...
- python+selenium之字符串切割操作
python+selenium之字符串切割操作 在Python中自带的一个切割方法split(),这个方法不带参数,就默认按照空格去切割字段,如果带参数,就按照参数去切割. 新建一个python文件, ...
- Python+Selenium自动化-模拟键盘操作
Python+Selenium自动化-模拟键盘操作 0.导入键盘类Keys() selenium中的Keys()类提供了大部分的键盘操作方法:通过send_keys()方法来模拟键盘上的按键. # ...
- Python+Selenium自动化 模拟鼠标操作
Python+Selenium自动化 模拟鼠标操作 在webdriver中,鼠标的一些操作如:双击.右击.悬停.拖动等都被封装在ActionChains类中,我们只用在需要使用的时候,导入这个类就 ...
- python+selenium文本框对象以及按钮对象操作
文本框对象 from selenium import webdriverfrom time import sleep driver = webdriver.Firefox() # 指定和打开浏览器ur ...
- Python+Selenium学习--操作测试对象
场景 前面已经讲解了如果定位对象,定位之后需要对这个对象进行操作.是鼠标点击还是键盘输入,取决于我们定位的对象缩支持的操作. webdriver中比较常用的操作元素的方法有下面几个: clear ...
- python+selenium 滑动滚动条的操作
工作中碰到一种情况就是,要定位的元素需要滚动条滑到下方后才可以显示出来. 这种情况下,就要先滑动滚动条,再定位元素. 那么滑动滚动条我以前记录了appium中的操作,那么,selenium中该如何操作 ...
- python+selenium:浏览器webdriver操作(1)--基本对象定位
1.简单对象的定位-----自动化测试的核心 对象的定位应该是自动化测试的核心,要想操作一个对象,首先应该识别这个对象.一个对象就是一个人一样,他会有各种的特征(属性),如比我们可以通过一个人的身份证 ...
- python+selenium之浏览器滚动条操作
from selenium import webdriver import time #访问百度 driver=webdriver.Ie() driver.get("http://www.b ...
随机推荐
- 使用navcat进行筛选和排序
- Deepin(Ubuntu)安装rpm软件包
1.首先安装alien和fakeroot这两个软件,alien可以将rpm转换为deb包. 在终端中输入命令 sudo apt-get install alien fakeroot 2.使用alien ...
- selenium定位
https://www.cnblogs.com/programer-xinmu78/p/10881766.html https://www.cnblogs.com/eastonliu/p/908830 ...
- VS2015开发常用快捷键
以下内容均Ctrl+后面的按钮 M-O\P折叠 K-F 格式化 K-U\C注释 K-S侧外代码-(区域代码) 代码片段 ctor 自动生成默认的构造函数 prop 自动生成get set方法 cw 自 ...
- 一、创建并打包Cordova的App工程
1.创建ionic4 & Angular项目 ionic start myApp tabs --type=angular 2.添加ios和android平台 ionic cordova pre ...
- linux运维、架构之路-Kubernetes集群部署TLS双向认证
一.kubernetes的认证授权 Kubernetes集群的所有操作基本上都是通过kube-apiserver这个组件进行的,它提供HTTP RESTful形式的API供集群内外客户端调 ...
- div拖拽到iframe上方 导致 缩放和拖拽的不平滑和鼠标事件未放开 解决方法
思路一:用在开始进行缩放(触发了resizable的start事件)为iframe添加z-index属性,将iframe放置在最下层. $("#draggable").resiza ...
- 10分钟学会React Context API
Create-react-app来学习这个功能: 注意下面代码红色的即可,非常简单. 在小项目里Context API完全可以替换掉react-redux. 修改app.js import React ...
- 软件工程 in MSRA Code Search-第二次结对编程
重现基线模型 我们选择了 code2vec 模型进行复现.该模型由 Uri Alon 等作者于 2018 年提出. 模型思路: 从代码与普通语言相比的特殊性入手,首先,对于输入的代码段,作者考虑到尽管 ...
- hihocoder1286 : 子矩阵求和
http://hihocoder.com/problemset/problem/1286 题解 NB分析题. 首先我们令\(s[i][j]\)表示以\((i,j)\)为左上角的矩形的权值和. 因为\( ...