Selenium 常用控件用法

1、文本框

  

  上图中,如何定位搜索文本框,并输入搜索内容进行搜索

  首先:利用方法 find_element_by_xpath定位元素:inputElements = self.driver.find_element_by_xpath("//input[@class='W_input']")

  其次:在文本框中输入要搜索的内容:inputElements.send_keys(u'足球') #在文本框中输入“足球”

  最后:点击回车,进行搜索:inputElements.send_keys(Keys.ENTER)

  上面这种方式效率较低,效率较高的方式为执行js脚本:

  js = "var obj = document.getElementsByName('keyword')[0];obj.value='足球';"

  self.driver.execute_script(js)

2、href链接

  第一种情况:href中内容为链接地址:如下图

    

    这种情况如何打开链接?

    首先定位元素:nextElement = self.driver.find_element_by_xpath("//a[@class='page next S_txt1 S_line1']")

    获取href链接:nextUrl = nextElement.get_attribute('href')
    打开链接:     self.driver.get(nextUrl)

  第二种情况:href中内容为“javascript:void(0);”:如下图

  

  如何打开上图中“高级搜索”这个链接

  定位元素:adv_elements = self.driver.find_element_by_xpath("//a[@class='adv_settiong']")

   打开:adv_elements.click()

3、radio

  选择对应的radio

  

  

ori_elements = self.driver.find_element_by_id("radio03")
ori_elements.click()

4、下拉列表

  

  

  1、直接定位

  self.driver.find_element_by_xpath("//select[@name='prov']/option[@value='11']").click() 

  2、Select模块(index):直接根据属性或索引定位  

  先要导入select方法:from selenium.webdriver.support.select import Select  

  然后通过select选项的索引来定位选择对应选项(从0开始计数),如选择第三个选项:select_by_index(2)

  prov = self.driver.find_element_by_xpath("//select[@name='prov']")

  Select(prov).select_by_index(2)#索引从0开始

  3、Select模块(value):直接根据属性或索引定位

  Select模块里面除了index的方法,还有一个方法,通过选项的value值来定位。每个选项,都有对应的value值

  prov = self.driver.find_element_by_xpath("//select[@name='prov']")

  Select(prov).select_by_value("11")

  4、Select模块(text)

  Select模块里面还有一个更加高级的功能,可以直接通过选项的文本内容来定位。 

  prov = self.driver.find_element_by_xpath("//select[@name='prov']")

  Select(prov).select_by_visible_text(u'北京')

5、时间控件

  

  把时间控件的只读属性去掉,直接赋给时间控件时间

  第一种方式:

    startTime = self.driver.find_element_by_xpath("//input[@name='stime']")

    js = 'document.getElementsByName("stime")[0].removeAttribute("readonly")'

    #js = 'document.getElementByID("stime").removeAttribute("readonly")'

    self.driver.execute_script(js)

    startTime.clear()

    startTime.send_keys("2017-03-25")

    这种方式效率较低

  第二种方式是执行js脚本,效率较高:

    js = 'var obj = document.getElementsByName("stime")[0];obj.removeAttribute("readonly");obj.value="2017-03-25";'

    self.driver.execute_script(js)

    两行代码就可以搞定

[Python爬虫] 之六:Selenium 常用控件用法的更多相关文章

  1. iOS开发之六:常用控件--UIImageView的使用

    UIImageView是我们做iOS开发用的非常多的一个控件,IOS中的各种图片,包括头像,有的背景图片等基本都要用到这个控件. 1.常用的属性以及方法 <span style="fo ...

  2. Android笔记---常用控件以及用法

    这篇文章主要记录下Android的常用控件以及使用的方法,Android 给我们提供了大量的UI控件,合理地使用这些控件就可以非常轻松地编写出相当不错的界面,这些是Android学习的基础,没有什么业 ...

  3. MFC编程入门之二十(常用控件:静态文本框)

    上一节讲了颜色对话框之后,关于对话框的使用和各种通用对话框的介绍就到此为止了.从本节开始将讲解各种常用控件的用法.常用控件主要包括:静态文本框.编辑框.单选按钮.复选框.分组框.列表框.组合框.图片控 ...

  4. python爬虫:一些常用的爬虫技巧

    python爬虫:一些常用的爬虫技巧 1.基本抓取网页 get方法: post方法: 2.使用代理IP 在开发爬虫过程中经常会遇到IP被封掉的情况,这时就需要用到代理IP; 在urllib2包中有Pr ...

  5. C# 常用控件属性及方法介绍

      C#常用控件属性及方法介绍                                               目录 1.窗体(Form) 2.Label (标签)控件 3.TextBox ...

  6. CustomValidator控件用法

    虽然大部分时间一直从事asp.net的开发,对于一些常用的asp.net服务器端验证控件及它们的组合使用比较熟悉,如:CompareValidator ——比较验证控件RangeValidator — ...

  7. EasyUI常用控件禁用方法

    EasyUI常用控件禁用方法: 1.validatebox可以用的用法:前两种适用于单个的validatebox; 第三种应用于整个form里面的输入框; <1>.$("#id& ...

  8. VS2010/MFC编程入门之二十二(常用控件:按钮控件Button、Radio Button和Check Box)

    言归正传,鸡啄米上一节中讲了编辑框的用法,本节继续讲解常用控件--按钮控件的使用. 按钮控件简介 按钮控件包括命令按钮(Button).单选按钮(Radio Button)和复选框(Check Box ...

  9. VS2010/MFC编程入门之二十(常用控件:静态文本框)

    上一节鸡啄米讲了颜色对话框之后,关于对话框的使用和各种通用对话框的介绍就到此为止了.从本节开始鸡啄米将讲解各种常用控件的用法.常用控件主要包括:静态文本框.编辑框.单选按钮.复选框.分组框.列表框.组 ...

随机推荐

  1. 洛谷P2047 [NOI2007]社交网络 [图论,最短路计数]

    题目传送门 社交网络 题目描述 在社交网络(social network)的研究中,我们常常使用图论概念去解释一些社会现象.不妨看这样的一个问题.在一个社交圈子里有n个人,人与人之间有不同程度的关系. ...

  2. Python数据类型-列表(list)增删改查

    1.添加元素 添加单个元素:使用append(object)函数可以为列表添加单个元素,参数object为对象:也就是说所有Python的对象都可以添加到列表中. 添加多个元素(合并列表):使用ext ...

  3. 第9天-BOM和DOM

    什么是DOM 文档对象模型(Document Object Model),DOM作用:可以去修改网页内容.样式.结构. 每个浏览器都会把html文档解析成dom树,就可以用相关方法和属性操作网页元素 ...

  4. css加载方式link和@import的区别!

    本质上,这两种方式都是为了加载CSS文件,但还是存在着细微的差别. 1. 老祖宗的差别.link属于XHTML标签,而@import完全是CSS提供的一种方式. link标签除了可以加载CSS外,还可 ...

  5. 【BZOJ 4455】 4455: [Zjoi2016]小星星 (容斥原理+树形DP)

    4455: [Zjoi2016]小星星 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 426  Solved: 255 Description 小Y是 ...

  6. HDU 1011 Starship Troopers 树形+背包dp

    http://acm.hdu.edu.cn/showproblem.php?pid=1011   题意:每个节点有两个值bug和brain,当清扫该节点的所有bug时就得到brain值,只有当父节点被 ...

  7. HDU1251 统计难题 trie树 简单

    http://acm.hdu.edu.cn/showproblem.php?pid=1251 题意: 找前缀数量 裸模板 #include<cstdio> #include<cstr ...

  8. LinkCutTree 总结

    最近学习了LinkCutTree,总结一下. LinkCutTree是一种数据结构(是Tree Decomposition中的一种),她维护的一般是无向图(一个森林),支持连边.删边.链修改.链查询( ...

  9. Effective Java部分读书笔记

    2.创建和销毁对象 1.使用静态工厂方法代替构造器 一般使用构造器(构造函数)创建对象实例,还可以使用静态工厂方法来创建对象实例. 优点 使用静态工厂方法代替构造器创建对象实例有以下优点: 1)静态构 ...

  10. Codeforces Beta Round #8 C. Looking for Order 状压

    C. Looking for Order 题目连接: http://www.codeforces.com/contest/8/problem/C Description Girl Lena likes ...