Selenium-几种操作

元素定位之后就要对它进行操作了,常见的集中操作如下:

click()  点击元素  eg.输入内容后,点击操作

send_keys("内容")  模拟按键输入  eg:百度输入框,输入内容

clear()  清除元素的内容  eg:清除百度输入框的内容

submit()  提交表单  eg:driver.find_element_by_id("su").submit()  #百度的搜索按钮,可以用click,也可以用submit

text  获取元素的文本内容  eg:登录帐号后,提取帐号名称,并作判断,是否登录成功

is_displayed  判断元素是否可见  eg:driver.find_element_by_id("kw").is_displayed()

 

#! /usr/bin/env python
#coding=utf-8

'''
元素定位,下面的方法都要掌握,应用中一种不行就换个方式
'''

from selenium import webdriver
import time

url = "http://www.baidu.com"
driver = webdriver.Firefox()
driver.get(url)
time.sleep(5)

#识别元素并操作
#一般有如下几种方法,其中id最为常用.这里需要注意识别元素一定要用唯一id
#记忆方法的时候,注意规律即可,非常容易记忆

#模拟输入
driver.find_element_by_id("kw").send_keys("博客园")
#模拟表单的提交按钮操作,新版百度搜索不需要这个了,他会自动搜索,再次看出ui的维护成本很高
#driver.find_element_by_id("kw").submit()
#driver.find_element_by_name("wd").send_keys("博客园")
#driver.find_element_by_class_name("s_ipt").send_keys("博客园")
time.sleep(5)


'''
#点击事件
driver.get(url)
driver.find_element_by_link_text("新闻").click()
time.sleep(5)

#对于超级连接比较长的可以尝试采用下面的方法,类似一种模糊匹配
driver.find_element_by_partial_link_text("首页").click()
time.sleep(5)


#xpath神器,理论上来说,没有path定位不到的元素
#这里使用firepath查看
#xpath你理解为树形结构就OK,我们也可以通过类似上下级的关系来一层层定位


driver.get(url)
driver.find_element_by_xpath(".//*[@id='kw']").send_keys("博客园")
#driver.find_element_by_id("su").submit()
time.sleep(5)

#清除内容
driver.find_element_by_id("kw").clear()
time.sleep(5)
#返回
driver.back()
time.sleep(5)

#利用两个元素属性进行唯一定位 and or,只适用于xpath
driver.find_element_by_xpath(".//*[@id='kw' and @name='wd']").send_keys("博客园")
time.sleep(5)

#获取元素的文本内容
driver.get("http://blog.csdn.net/jillliang/article/details/8747810")
time.sleep(5)
#blog_name = driver.find_element_by_class_name("header").text
#blog_name = driver.find_element_by_id("blog_title").text
blog_name = driver.find_element_by_xpath(".//*[@id='blog_title']/h2/a").text
print(blog_name)
'''
driver.quit()

  

 

posted @ 2017-09-02 22:43  R-Bear  阅读(547)  评论(0编辑  收藏  举报