<自动化测试>之<Selenium API 的用法1>

今天,简单,举例说一下在用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()
"""

 1 from selenium import webdriver
 2 import os
 3 import time
 4 
 5 path = os.getcwd()
 6 path = 'file://' + path.split('test_case')[0] + 'demo_html' + os.sep + 'test.html'
 7 
 8 test_html = path.decode('gbk').encode('utf-8')#这是转码
 9 baidu_url = 'http://www.baidu.com'
10 
11 dr = webdriver.Firefox()
12 dr.implicitly_wait(30)
13 dr.get(baidu_url)
14 
15 # 百度搜索框的html
16 # <input type="text" class="s_ipt" name="wd" id="kw" maxlength="100" autocomplete="off">
17 
18 # 1.根据id属性定位, id="kw"
19 dr.find_element_by_id('kw').clear()
20 dr.find_element_by_id('kw').send_keys('python')
21 
22 # 2.根据name属性定位, name="wd"
23 dr.find_element_by_name('wd').clear()
24 dr.find_element_by_name('wd').send_keys('python')
25 
26 # 3.根据class属性定位, class="s_ipt"
27 dr.find_element_by_class_name('s_ipt').clear()
28 dr.find_element_by_class_name('s_ipt').send_keys('python')
29 
30 # 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...

 1 #!/usr/bin/env python
 2 # -*- coding: utf-8 -*-
 3 """
 4 @author: xiang.huang@pactera.com
 5 @contact: it_stu@163.com
 6 @others: DTStudio, All rights reserved-- Created on 2017/5/10
 7 @desc: 
 8 """
 9 import os
10 import sys
11 import time
12 from selenium import webdriver
13 
14 
15 path = os.path.abspath(os.path.dirname(sys.argv[0]))
16 path = 'file://' + path.split('test_case')[0] + 'demo_html' + os.sep + 'test.html'
17 
18 
19 demo_page = path.decode('gbk').encode('utf-8')
20 
21 
22 
23 dr = webdriver.Firefox()
24 dr.maximize_window()
25 dr.implicitly_wait(30)
26 dr.get(demo_page)
27 
28 
29 # 勾选所有checkbox
30 books = dr.find_elements_by_name("book")
31 for book in books:
32 book.click()
33 
34 
35 dr.find_element_by_id("submitOrder").click()
36 
37 
38 time.sleep(3)
39 
40 
41 dr.quit()
原文地址:https://www.cnblogs.com/itstu/p/6897112.html