前言
前面的几篇都是讲如何定位一个元素,有时候一个页面上有很多个对象需要操作,如果一个个去定位的话,比较繁琐,这时候就可以定位一组对象。
webdriver提供了定位一组元素的方法,跟前面八种定位方式其实一样,只是前面是单数,这里是复数形式:find_elements
本篇以百度搜索为例,从搜索结果中随机选择一条搜索结果,然后点击查看。
一、定位搜索结果
1.在百度搜索框输入关键字“博客园”后,用F12查看页面元素,可以看到这些搜索结果有共同的属性。
2.从搜索的结果可以看到,他们的父元素一样:<h3 class="t">
3.标签都一样,且都是第一个a
4.于是这里可以用xpath定位
# coding:utf-8 from selenium import webdriver import time driver=webdriver.Chrome() driver.get("https://www.baidu.com") driver.find_element_by_name("wd").send_keys("博客园") time.sleep(3) driver.find_element_by_id("su").click() r=driver.find_elements_by_xpath("//h3[@class='t']/a[1]")
二、确认定位结果
1.前面的定位策略得到的结果是a标签的所有内容,我们只需要a标签里面的部分内容。
2.于是可以获取对象的属性,来验证下是不是定位准确了。这里可以获取href属性,打印出url地址
for i in r: print(i.get_attribute("href"))
三、随机函数
1.搜索结果有7条,从这7条中随机取一个就ok了;也可以len(r)获取条数
2.先导入随机函数:import random
3.设置随机值范围为0~6:n=random.randint(0,6);
# coding:utf-8 from selenium import webdriver import time import random driver=webdriver.Chrome() driver.get("https://www.baidu.com") driver.find_element_by_name("wd").send_keys("博客园") time.sleep(3) driver.find_element_by_id("su").click() r=driver.find_elements_by_xpath("//h3[@class='t']/a[1]") # print(type(r),r) for i in r: print(i.get_attribute("href")) n=random.randint(1,len(r)) #取值1-7;所以r的脚标为n-1,即0-6 print("查询结果的第{}条url为:{}".format(n,r[n-1].get_attribute("href")))
运行结果
http://www.baidu.com/link?url=na4QKwFJC63VKzWvhM_5iJmMxMjCt61Nm0AG0m9MUWEdYvNVFLFozx8BMf62Ey12 http://www.baidu.com/link?url=LgB5Fx0TpVFP3byCejOjkdDZTS6zdP-JM9_HDDBGBTlrOpPaJewnodT3IH2Uas5o http://www.baidu.com/link?url=FLKuauHhYeYzPHHcuy47KfIININ0VJLE7SxxWsgRAJtYjHVlKdUnY7BSiNpVM4uO http://www.baidu.com/link?url=hIqIAaxg8oDh2NZZUqxXy4pJzh0M8rPhHrje97oAZF28Ixru3r3agQe9tWcrS9zW http://www.baidu.com/link?url=kXjX6Hafm4udqMuExbT5unME7DiSLlHYuJJFcE-KDfenSvwli9EPja2TpzvMm-B- http://www.baidu.com/link?url=QNWevjIgcnt7IF7HxwF6ga6T8mq5-_eEN6Q8LIzkUwmwnVNs0oqW667Ly_GQCAtQ http://www.baidu.com/link?url=kDWd3gSyNpNr-QJX496m6bZ7T5ihEVRs9cCCSmz2qN7sHNgebiXu8d7NdXqZ2YNx 查询结果的第2条url为:http://www.baidu.com/link?url=LgB5Fx0TpVFP3byCejOjkdDZTS6zdP-JM9_HDDBGBTlrOpPaJewnodT3IH2Uas5o
四、随机打开url
1.从返回结果中随机取一个url地址
2.通过get方法打开url
3.其实这种方式是接口测试了,不属于UI自动化,这里只是开阔下思维
driver.get(nurl)
五、通过click点击打开
1.前面那种方法,是直接访问url地址,算是接口测试的范畴了,真正模拟用户点击行为,使用click的方法
# coding:utf-8 from selenium import webdriver import time import random driver=webdriver.Chrome() driver.get("https://www.baidu.com") driver.find_element_by_name("wd").send_keys("博客园") time.sleep(3) # driver.find_element_by_id("su").click() driver.find_element_by_name("wd").submit() r=driver.find_elements_by_xpath("//h3[@class='t']/a[1]") # print(type(r),r) # for i in r: # print(i.get_attribute("href")) n=random.randint(1,len(r)) #取值1-7;所以r的脚标为n-1,即0-6 nurl=r[n-1].get_attribute("href") print("查询结果的第{}条url为:{}".format(n,nurl)) # driver.get(nurl) r[n-1].click()
运行结果:
查询结果的第2条url为:http://www.baidu.com/link?url=O3LdwGFFL-xbVh_G-kAwRtND98nFqpHtfUkmMqOtezjmus9aDxUMb1nGtGUgZK0H
上面代码中搜索框输入关键字后,没有使用click(),而是用的submit方法,submit()相当于回车键