今天,简单,举例说一下在用python+selenium中元素定位的主要方法,第一部分是单个元素的操作,第二部分是一类元素的操作,实际操作中注意区分

#!/usr/bin/env python

# -*- coding: utf-8 -*-
"""
@author: xiang.huang@pactera.com
@contact: it_stu@163.com
@others: DTStudio, All rights reserved-- Created on 2017/5/09
@desc: 讲讲web项目中常用的方法属性
webdriver 提供了八种元素定位方法:
id、name、class name、tag name、link text、partial link text、xpath、css selector
在 Python 语言中对应的定位方法如下:
find_element_by_id()
find_element_by_name()
find_element_by_class_name()
find_element_by_tag_name()
find_element_by_link_text()
find_element_by_partial_link_text()
find_element_by_xpath()
find_element_by_css_selector()
"""

 from selenium import webdriver
import os
import time path = os.getcwd()
path = 'file://' + path.split('test_case')[0] + 'demo_html' + os.sep + 'test.html' test_html = path.decode('gbk').encode('utf-8')#这是转码
baidu_url = 'http://www.baidu.com' dr = webdriver.Firefox()
dr.implicitly_wait(30)
dr.get(baidu_url) # 百度搜索框的html
# <input type="text" class="s_ipt" name="wd" id="kw" maxlength="100" autocomplete="off"> # 1.根据id属性定位, id="kw"
dr.find_element_by_id('kw').clear()
dr.find_element_by_id('kw').send_keys('python') # 2.根据name属性定位, name="wd"
dr.find_element_by_name('wd').clear()
dr.find_element_by_name('wd').send_keys('python') # 3.根据class属性定位, class="s_ipt"
dr.find_element_by_class_name('s_ipt').clear()
dr.find_element_by_class_name('s_ipt').send_keys('python') # 4.find_element_by_tag_name(), 搜索框的标签是<input></input> 1 # TIPS:通常很少使用tagname定位,因为页面上包含的相同标签数太多时,
2 # 比如_testfile页面,包含了3个input元素,使用find_element_by_tag_name('input')时,
3 # driver是无法区分出你到底要对哪个input操作,这里我们使用find_elements_by_tag_name('input')
4 # 注意这里find_elements_xxx的用法
5 dr.get(test_html)
6 eles = dr.find_elements_by_tag_name('input')
7 for e in eles:
8 if e.get_attribute('id') == 'username':
9 e.send_keys(u'这是用户名输入框')
10
11 # 5.find_element_by_link_text()
12 # <a onmousedown="return ns_c({'fm':'behs','tab':'tj_duty'})" href="http://www.baidu.com/duty/">使用百度前必读</a>
13 # 加 u 的作用是把中文字符串转换成unicode 编码
14 dr.get(baidu_url)
15 dr.find_element_by_link_text(u'使用百度前必读').click()
16
17 # 6.find_element_by_partial_link_text(), partial link text是对link text的补充。
18 # 只要取文本链接中的一部分即可,下面2行代码定位到的是同一个元素
19 dr.back() # 返回上一页
20 dr.find_element_by_partial_link_text(u'使用百度').click()
21 dr.back()
22 dr.find_element_by_partial_link_text(u'百度前必读').click()
23
24 # 7.find_element_by_xpath()
25 dr.back()
26 # 7.1 使用绝对路径xpath定位
27 dr.find_element_by_xpath("/html/body/div[3]/div[1]/div/div[1]/div/form/span[1]/input").send_keys('0')
28 # 7.2 使用相对路径的xpath定位
29 # 关于xpath的技巧,建议亲们在后期深入学习时重点研究下。通过常规方法不能定位元素时,使用xpath/css肯定是可行的。
30 # <input type="text" class="s_ipt" name="wd" id="kw" maxlength="100" autocomplete="off">
31 dr.find_element_by_xpath("//input[@id='kw']").send_keys('1')
32 dr.find_element_by_xpath("//input[@name='wd']").send_keys('2')
33 dr.find_element_by_xpath("//input[@class='s_ipt']").send_keys('3')
34 dr.find_element_by_xpath("//*[@class='s_ipt']").send_keys('4')
35
36 # 8.find_element_by_css_selector()
37 dr.find_element_by_css_selector(".s_ipt").send_keys('5') # .号后面跟的是class属性, class="s_ipt"
38 dr.find_element_by_css_selector("#kw").send_keys('6') # #号后面跟的是id属性, id="kw"
39
40 # 这里停留30秒,方便大家看下效果,百度输入框里输入的是不是0123456
41 time.sleep(30)
42
43 #
44 print u"搜索按钮的文字是>>>", dr.find_element_by_id('su').text
45
46 dr.get(baidu_url)
47 news_link = dr.find_element_by_link_text(u"新闻")
48 print u"新闻链接是>>>", news_link.get_attribute("href")
49 print u"新闻链接的name属性是>>>", news_link.get_attribute("name")
50
51 # 9.退出,有2种方法
52 dr.quit() # 关闭【所有窗口】,并退出相关的驱动程序,
53 # dr.close() # 关闭【当前窗口】,注意两者的区别
54
55 # find_element_by_xxxx 和find_elements_by_xxx的区别:
56 # find_element_by_xxxx:定位一个元素

# find_elements_by_xxx:定位一组元素,得到的是一个list,要从list取值后再对每个元素做具体操作

还有再对页面多元素定位操纵 即是 find_elements.by...

 #!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
@author: xiang.huang@pactera.com
@contact: it_stu@163.com
@others: DTStudio, All rights reserved-- Created on 2017/5/10
@desc:
"""
import os
import sys
import time
from selenium import webdriver path = os.path.abspath(os.path.dirname(sys.argv[0]))
path = 'file://' + path.split('test_case')[0] + 'demo_html' + os.sep + 'test.html' demo_page = path.decode('gbk').encode('utf-8') dr = webdriver.Firefox()
dr.maximize_window()
dr.implicitly_wait(30)
dr.get(demo_page) # 勾选所有checkbox
books = dr.find_elements_by_name("book")
for book in books:
book.click() dr.find_element_by_id("submitOrder").click() time.sleep(3) dr.quit()

<自动化测试>之<Selenium API 的用法1>的更多相关文章

  1. 彻底弄清c标准库中string.h里的常用函数用法

    在我们平常写的c/c++程序,一些算法题中,我们常常会用到c标准库中string.h文件中的函数,这些函数主要用于处理内存,字符串相关操作,是很有用的工具函数.而且有些时候,在笔试或面试中也会出现让你 ...

  2. 走进C标准库(8)——"string.h"中函数的实现相关字符串操作函数

    我的strcat: char *strcat(char *dest,char *src) { char * reval = dest; while(*dest) dest++; while(*src) ...

  3. 走进C标准库(3)——"stdio.h"中的getc和ungetc

    接前文. 再来看看getc和ungetc的实现.在看这两个函数的实现之前,我们先来想一想这两个函数分别需要做的工作. int getc(FILE *stream) 说明:函数getc从stream指向 ...

  4. 走进C标准库(2)——"stdio.h"中的fopen函数

    其他的库文件看起来没有什么实现层面的知识可以探究的,所以,直接来看stdio.h. 1.茶余饭后的杂谈,有趣的历史 在过去的几十年中,独立于设备的输入输出模型得到了飞速的发展,标准C从这个改善的模型中 ...

  5. 走进C标准库(1)——assert.h,ctype.h

    默默觉得原来的阅读笔记的名字太土了,改了个名字,叫做走进C标准库. 自己就是菜鸟一只,第一次具体看C标准库,文章参杂了对<the standard C library>的阅读和对源码的一些 ...

  6. C 非标准库(conio.h)

    所谓的 C 标准库(C standard library),是指在 ISO C 或者 POSIX 标准中定义的: POSIX is a superset(超集) of the standard C l ...

  7. 走进C标准库(4)——"stdio.h"中的putc

    花了点时间把园子弄得好看了点,现在继续. 函数名: putc 功  能: 输出一字符到指定流中 用  法: int putc(int ch, FILE *stream); #define _putc_ ...

  8. 走进C标准库(5)——"stdio.h"中的其他部分函数

    函数介绍来自:http://ganquan.info/standard-c/ 函数名: freopen 功  能: 替换一个流 用  法: FILE *freopen(char *filename, ...

  9. 走进C标准库(6)——"string.h"中函数的实现memchr

    我写的memchr: void *memchr(const void *buf, char ch, unsigned count){ unsigned ; while(*(buf++) != ch & ...

  10. 走进C标准库(7)——"string.h"中函数的实现memcmp,memcpy,memmove,memset

    我的memcmp: int memcmp(void *buf1, void *buf2, unsigned int count){ int reval; while(count && ...

随机推荐

  1. Java总结第一期

    神奇的小阳阳阳再度归来,大家一定想我了吧~哦,谢谢,谢谢,谢谢各位的掌声,thank you,thank you@ 第一章: 下面给大家简单介绍Java: Java技术可以应用在几乎所有类型和规模的设 ...

  2. js俩习题

    需求,现在要求两个按钮,点击1,背景为红色,点击2,背景为黄色 *****html代码——————————————————————————————————————————————————<!DO ...

  3. MySQL中truncate误操作后的数据恢复案例

    MySQL中truncate误操作后的数据恢复案例 这篇文章主要介绍了MySQL中truncate误操作后的数据恢复案例,主要是要从日志中定位到truncate操作的地方然后备份之前丢失的数据,需要的 ...

  4. 17. Jmeter-取样器一

    jmeter-sampler介绍与使用 HTTP请求 Test Action Debug Sampler AJP/1.3 Sampler Access Log Sampler BeanShell Sa ...

  5. HTMLtr 标签的 valign 属性

    valign 属性规定表格行中内容的垂直对齐方式. <table width="100%" border="1"> <tr valign=&q ...

  6. ecs centos7.3 搭建vsftpd 虚拟用户

    FTP介绍 FTP会话时包含了两个通道,一个叫控制通道,端口号21:一个叫数据通道,端口号20. 控制通道:控制通道是和FTP服务器进行沟通的通道,连接FTP,发送FTP指令都是通过控制通道来完成的. ...

  7. 树的直径(BFS)

    ][];];];];,,;vis[i]=; ; j <= n ; j++){ ){;//标记 res[j]=res[root]+; ; i <= n- ; i++){; data[b][a ...

  8. Java管理Cookie增删改查操作。

    Cookie属性 了解这几个属性之后,就知道如何进行Cookie的操作了. name Cookie的名称. value Cookie的值. maxAge Cookie的失效时间,有以下几种值,默认为- ...

  9. C++中的赋值兼容性和重写

    1,父子间的赋值兼容: 1,子类对象可以当做父类对象使用(赋值兼容性): 1,子类对象可以直接赋值给父类对象: 2,子类对象可以直接初始化父类对象: 3,父类指针可以直接指向子类对象(得到的是子类对象 ...

  10. Javascript基础三(函数)

    函数第一节: 1.函数的概念及作用     函数是由事件驱动的或者当他被调用时可执行的可重复使用的代码块.   具备一点功能的代码段,代码段来实现具体的功能.要想实现一个函数的功能需要对函数进行调用. ...