API讲解
-
coding = utf-8
可加可不加,开发人员喜欢加一下,防止乱码。 -
from selenium import webdriver
要想使用selenium 的webdriver 里的函数,首先把包导进来 -
browser = webdriver.Firefox()
我们需要操控哪个浏览器呢?Chrome ,当然也可以换成Ie 或Firefox。browser 可以随便取,但后面要用它操纵各种函数执行。 -
browser.find_element_by_id(“kw”).send_keys(“selenium”)
一个控件有若干属性id 、name、(也可以用其它方式定位),百度输入框的id 叫kw ,我要在输入框里输入selenium 。 -
browser.find_element_by_id(“su”).click()
搜索的按钮的id 叫su ,我需要点一下按钮( click() )。 -
browser.quit()
退出并关闭窗口的每一个相关的驱动程序。 -
browser.close()
关闭当前窗口。
close方法关闭当前的浏览器窗口,quit方法不仅关闭窗口,还会彻底的退出webdriver,释放与driver server之间
的连接。所以简单来说quit是更加彻底的close,quit会更好的释放资源
元素的定位
对象的定位应该是自动化测试的核心,要想操作一个对象,首先应该识别这个对象。一个对象就是一个人一样,他
会有各种的特征(属性),如比我们可以通过一个人的身份证号,姓名,或者他住在哪个街道、楼层、门牌找到这
个人。
那么一个对象也有类似的属性,我们可以通过这个属性找到这对象。
webdriver 提供了一系列的对象定位方法,常用的有以下几种
1.id
2.name
3.class name
4.link text
5.partial link text
6.tag name
7.xpath
8.css selector
这是一个百度输入框的html
<input id="kw" class="s_ipt" type="text" maxlength="100" name="wd" autocomplete="off">
#coding=utf-8
from selenium import webdriver
import time
browser = webdriver.Chrome()
browser.get("http://www.baidu.com")
#########百度输入框的定位方式##########
#通过id 方式定位
browser.find_element_by_id("kw").send_keys("selenium")
#通过name 方式定位
browser.find_element_by_name("wd").send_keys("selenium")
#通过tag name 方式定位
browser.find_element_by_tag_name("input").send_keys("selenium") 不能成功,因为input太多了不唯一。
#通过class name 方式定位
browser.find_element_by_class_name("s_ipt").send_keys("selenium")
#通过CSS 方式定位
browser.find_element_by_css_selector("#kw").send_keys("selenium")
#通过xphan 方式定位
browser.find_element_by_xpath