主要是练习获取页面中的各元素,马克

 # 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方法识别页面元素的更多相关文章

  1. selenium采用xpath方法识别页面元素

    有些HTML页面中的元素中属性较少,经常有找不到id.class.name等常用属性的时候,这个时候xpath.css就能很好的识别到我们的元素. Firefox和chrome浏览器中均有xpath. ...

  2. Python3.x:Selenium中的webdriver进行页面元素定位

    Python3.x:Selenium中的webdriver进行页面元素定位 页面上的元素就像人一样,有各种属性,比如元素名字,元素id,元素属性(class属性,name属性)等等.webdriver ...

  3. selenium 总结篇,常见方法和页面元素的操作

    今天,总结一下selenium怎么操作web页面常见的元素. 主要有: 上传 alter dialog prompt dialog confirm dialog select list radio b ...

  4. selenium总结篇,常见方法和页面元素的操作【转】

    原文:http://www.cnblogs.com/tobecrazy/p/4570494.html 今天,总结一下selenium怎么操作web页面常见的元素. 主要有: 上传 alter dial ...

  5. selenium java maven 自动化测试(二) 页面元素获取与操作

    在第一节中,我们已经成功打开了页面,但是自动化测试必然包含了表单的填写与按钮的点击. 所以在第二章中我以博客园为例,完成按钮点击,表单填写 还是以代码为准,先上代码: package com.ryan ...

  6. Selenium WebDriver- 操作frame中的页面元素

    #encoding=utf-8 import unittest import time from selenium import webdriver from selenium.webdriver i ...

  7. Selenium WebDriver-通过ActionChains实现页面元素拖拽

    #encoding=utf-8 import unittest import time import chardet from selenium import webdriver class Visi ...

  8. python+selenium高亮显示正在操作的页面元素

    原文地址:https://blog.csdn.net/wxstar8/article/details/80801405 from selenium import webdriver import un ...

  9. selenium—用NoSuchElementException异常判断页面元素是否存在

    一.知识补充 1.find_element的一种使用方法: find_element(by=方法,value=值) 例如: find_element(by="id",value=& ...

随机推荐

  1. IDEA快捷建使用

    因为以前使用的IDE工具是Eclipse,所以在公司中都是用IDEA的情况下,换成了IDEA,感觉是好用了很多. 其他快捷键: Ctrl+Shift + Enter,语句完成 “!”,否定完成,输入表 ...

  2. JS 设计模式四 -- 模块模式

    概念 模块模式的思路 就是 就是单例模式添加私有属性和私有方法,减少全局变量的使用. 简单的代码结构: var singleMode = (function(){ // 创建私有变量 var priv ...

  3. 如何把Office365的更新从半年通道改成月度通道

    转自msdn,转发链接:www.cnblogs.com/Charltsing/p/Office365month.html 作者QQ: 564955427 建立一个Bat文件,写入 下面内容 setlo ...

  4. 使用python抓取数据之菜鸟爬虫1

    ''' Created on 2018-5-27 @author: yaoshuangqi ''' #本代码获取百度乐彩网站上的信息,只获取最近100期的双色球 import urllib.reque ...

  5. Linux学习之路1

    root用户 安装初始系统默认没有启动root用户,如下方式启动: l  sudo passwd l  连续输入两次密码,启动root用户 l  再登陆 登陆root用户 l  su root l  ...

  6. 继收购Magento十个月,Adobe推出Commerce Cloud商务云服务

    去年 5 月,软件巨头 Adobe 以 16.8 亿美元的价格,受过了 Magento .在经历了十个月的业务整合后,该公司终于推出了全新的 Commerce Cloud 商务云服务.据悉,其本质上是 ...

  7. react 生命周期函数介绍

    constructor():构造函数 执行:组件加载钱最先调用一次,仅调用一次. 作用:定义状态机变量. 注意:第一个语句必须为super(), 否则会报错:'this' is not allowed ...

  8. request 获取body内容

    public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException ...

  9. js实现一个长页面中的图片懒加载即滚动到其位置才加载

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  10. python中__init__和__new__的区别

    参考:https://my.oschina.net/liuyuantao/blog/747164 python中__metaclass的详解 参考:https://www.cnblogs.com/ia ...