selenium采用find_element_by方法识别页面元素
主要是练习获取页面中的各元素,马克
# coding:utf-8
import time
from selenium import webdriver
import unittest
from pythontest.commlib.baselib import * #引用封装后的日志系统
log = TestLog().getlog()
class BaiBu(unittest.TestCase):
u'''【百度.类】'''
def setUp(self):
self.browser = webdriver.Firefox()
self.browser.get("http://www.baidu.com")
self.browser.implicitly_wait(10)
#self.base = Screen(self.browser) def tearDown(self):
self.browser.quit() def test_search(self):
u'''采用id,class,name等属性识别元素'''
#<input id="kw" name="wd" class="s_ipt" value="" maxlength="255" autocomplete="off">
#<input id="su" value="百度一下" class="bg s_btn" type="submit">
#识别id属性
self.browser.find_element_by_id("kw").send_keys("python")
self.browser.find_element_by_id("su").submit()
print self.browser.title
self.assertEqual(self.browser.title,u"百度一下,你就知道")
log.info("识别id属性,执行[find_element_by_id]") time.sleep(3) #识别name属性 <input id="su" value="百度一下" class="bg s_btn" type="submit">
self.browser.find_element_by_name("wd").clear() #清空原关键字
self.browser.find_element_by_name("wd").send_keys("python logging")
# class属性是比较特殊的一个,属性值可以有多个,中间是用空格隔开的
#self.browser.find_element_by_class_name("bg s_btn").submit() #使用class_name会报错
#self.browser.find_element_by_class_name("s_btn").submit() #第一种解决办法:class值取其中之一
#self.browser.find_element_by_class_name("bg").submit() #第一种解决办法:class值取其中之一
self.browser.find_element_by_css_selector(".bg.s_btn").submit() #第二种解决办法:使用css.selector,每个class值前面加.
log.info("识别name属性,执行[find_element_by_name]")
time.sleep(3) #识别class属性
self.browser.find_element_by_name("wd").clear() # 清空原关键字
self.browser.find_element_by_class_name("s_ipt").send_keys("selenium webdriver")
self.browser.find_element_by_class_name("s_btn").submit()
log.info("识别class属性,执行[find_element_by_class_name]")
time.sleep(3) def test_xpath(self):
u'''采用xpath识别元素'''
self.browser.find_element_by_xpath(".//*[@id='kw']").send_keys("xpath test") #采用id
self.browser.find_element_by_xpath(".//*[@id='su']").submit() #采用id
log.info("采用xpath识别页面中的属性,[id]") self.browser.find_element_by_xpath(".//*[@name='wd']").clear() # 清空原关键字 #采用name
self.browser.find_element_by_xpath(".//*[@class='s_ipt']").send_keys("selenium auto test") #采用class
self.browser.find_element_by_xpath(".//*[@type='submit']").submit() #采用type
log.info("采用xpath识别页面中的属性,[class、type]") if __name__ == "__main__":
unittest.main()
运行结果:
selenium采用find_element_by方法识别页面元素的更多相关文章
- selenium采用xpath方法识别页面元素
有些HTML页面中的元素中属性较少,经常有找不到id.class.name等常用属性的时候,这个时候xpath.css就能很好的识别到我们的元素. Firefox和chrome浏览器中均有xpath. ...
- Python3.x:Selenium中的webdriver进行页面元素定位
Python3.x:Selenium中的webdriver进行页面元素定位 页面上的元素就像人一样,有各种属性,比如元素名字,元素id,元素属性(class属性,name属性)等等.webdriver ...
- selenium 总结篇,常见方法和页面元素的操作
今天,总结一下selenium怎么操作web页面常见的元素. 主要有: 上传 alter dialog prompt dialog confirm dialog select list radio b ...
- selenium总结篇,常见方法和页面元素的操作【转】
原文:http://www.cnblogs.com/tobecrazy/p/4570494.html 今天,总结一下selenium怎么操作web页面常见的元素. 主要有: 上传 alter dial ...
- selenium java maven 自动化测试(二) 页面元素获取与操作
在第一节中,我们已经成功打开了页面,但是自动化测试必然包含了表单的填写与按钮的点击. 所以在第二章中我以博客园为例,完成按钮点击,表单填写 还是以代码为准,先上代码: package com.ryan ...
- Selenium WebDriver- 操作frame中的页面元素
#encoding=utf-8 import unittest import time from selenium import webdriver from selenium.webdriver i ...
- Selenium WebDriver-通过ActionChains实现页面元素拖拽
#encoding=utf-8 import unittest import time import chardet from selenium import webdriver class Visi ...
- python+selenium高亮显示正在操作的页面元素
原文地址:https://blog.csdn.net/wxstar8/article/details/80801405 from selenium import webdriver import un ...
- selenium—用NoSuchElementException异常判断页面元素是否存在
一.知识补充 1.find_element的一种使用方法: find_element(by=方法,value=值) 例如: find_element(by="id",value=& ...
随机推荐
- java 锁 Lock接口详解
一:java.util.concurrent.locks包下常用的类与接口(lock是jdk 1.5后新增的) (1)Lock和ReadWriteLock是两大锁的根接口,Lock代表实现类是Reen ...
- 函数的创建与区别和 prototype
https://www.cnblogs.com/haoxl/p/5267724.html(copy) https://www.cnblogs.com/loveyoume/p/6112044.html( ...
- web services + soap + wsdl 学习
什么是web services? 应用程序组件: 使用开放协议进行通信: 独立(self - contained )并可自我描述: 可通过使用UDDI来发现: 可被其他应用程序使用: XML是Web ...
- Plugin Kotlin was not installed: Cannot download
到 https://plugins.jetbrains.com/plugin/6954-kotlin下载对应版本(右键复制链接地址,用迅雷下载),放到androidstudio安装目录下的plugin ...
- model中的一些处理
3.setting.py中设置 主要有三个地方需要设置: MEDIA_URL = ‘/media/’,设置该路径为了在模板中定位图片的位置,<img src="{{ MEDIA_URL ...
- Java逆向工程SpringBoot + Mybatis Generator + MySQL
Java逆向工程SpringBoot+ Mybatis Generator + MySQL Meven pop.xml文件添加引用: <dependency> <groupId> ...
- beego框架开发投票网站(1) beego基础之运行逻辑
本文档需结合beego官方文档食用 博主也仅仅是边学边记录,不保证内容的正确性,请当做通俗读物来看待 首先 beego是一个基于go语言的框架 其次 beego是一个mvc框架 框架可以理解为对底层又 ...
- [BJOI2019]奥术神杖
https://www.luogu.org/problemnew/show/P5319 题解 首先观察我们要求的答案的形式: \[ \biggl(\prod V_i \biggr)^x\ \ \ x= ...
- k-均值聚类算法1
一.k-means算法: 1.优缺点: 优点:容易实现. 缺点:可能收敛到局部最小值,在大规模数据集上收敛较慢. 2.伪代码描述:
- 在不同DPI屏幕环境下,让图标显示的尺寸保持不变,使用 LoadImage() 加载图标
之前写过的一个客户端程序中,需要在状态栏上显示图标: 我当时使用的是:HICON LoadIcon(HINSTANCE hInstance, LPCTSTR lpIconName); 在DPI:125 ...