selenium+python笔记1

时间:2022-09-04 17:52:46
#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
@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 sys path = os.getcwd()
path = 'file://' + path.split('test_case')[0] + 'demo_html' + os.path.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>
# TIPS:通常很少使用tagname定位,因为页面上包含的相同标签数太多时,
# 比如_testfile页面,包含了3个input元素,使用find_element_by_tag_name('input')时,
# driver是无法区分出你到底要对哪个input操作,这里我们使用find_elements_by_tag_name('input')
# 注意这里find_elements_xxx的用法
dr.get(test_html)
eles = dr.find_elements_by_tag_name('input')
for e in eles:
if e.get_attribute('id') == 'username':
e.send_keys(u'这是用户名输入框') # 5.find_element_by_link_text()
# <a onmousedown="return ns_c({'fm':'behs','tab':'tj_duty'})" href="http://www.baidu.com/duty/">使用百度前必读</a>
# 加 u 的作用是把中文字符串转换成unicode 编码
dr.get(baidu_url)
dr.find_element_by_link_text(u'使用百度前必读').click() # 6.find_element_by_partial_link_text(), partial link text是对link text的补充。
# 只要取文本链接中的一部分即可,下面2行代码定位到的是同一个元素
dr.back() # 返回上一页
dr.find_element_by_partial_link_text(u'使用百度').click()
dr.back()
dr.find_element_by_partial_link_text(u'百度前必读').click() # 7.find_element_by_xpath()
dr.back()
# 7.1 使用绝对路径xpath定位
dr.find_element_by_xpath("/html/body/div[3]/div[1]/div/div[1]/div/form/span[1]/input").send_keys('')
# 7.2 使用相对路径的xpath定位
# 关于xpath的技巧,建议亲们在后期深入学习时重点研究下。通过常规方法不能定位元素时,使用xpath/css肯定是可行的。
# <input type="text" class="s_ipt" name="wd" id="kw" maxlength="100" autocomplete="off">
dr.find_element_by_xpath("//input[@id='kw']").send_keys('')
dr.find_element_by_xpath("//input[@name='wd']").send_keys('')
dr.find_element_by_xpath("//input[@class='s_ipt']").send_keys('')
dr.find_element_by_xpath("//*[@class='s_ipt']").send_keys('') # 8.find_element_by_css_selector()
dr.find_element_by_css_selector(".s_ipt").send_keys('') # .号后面跟的是class属性, class="s_ipt"
dr.find_element_by_css_selector("#kw").send_keys('') # #号后面跟的是id属性, id="kw" # 这里停留30秒,百度输入框里输入的是0123456
import time
time.sleep(30) #
print u"搜索按钮的文字是>>>", dr.find_element_by_id('su').text dr.get(baidu_url)
news_link = dr.find_element_by_link_text(u"新闻")
print u"新闻链接是>>>", news_link.get_attribute("href")
print u"新闻链接的name属性是>>>", news_link.get_attribute("name") # 9.退出,有2种方法
dr.quit() # 关闭【所有窗口】,并退出相关的驱动程序,
# dr.close() # 关闭【当前窗口】,注意两者的区别 # find_element_by_xxxx 和find_elements_by_xxx的区别:
# find_element_by_xxxx:定位一个元素
# find_elements_by_xxx:定位一组元素,得到的是一个list,要从list取值后再对每个元素做具体操作

selenium+python笔记1的更多相关文章

  1. selenium&plus;python笔记11

    #!/usr/bin/env python # -*- coding: utf-8 -*- """ @desc: search in mail box "&qu ...

  2. selenium&plus;python笔记10

    #!/usr/bin/env python # -*- coding: utf-8 -*- """ 我们多添加一些测试场景,比如:删除邮件,查找邮件,发送邮件等等 &qu ...

  3. selenium&plus;python笔记9

    #!/usr/bin/env python # -*- coding: utf-8 -*- """ @desc: delete mail 我们多添加一些测试场景,比如:删 ...

  4. selenium&plus;python笔记8

    #!/usr/bin/env python # -*- coding: utf-8 -*- """ @desc: 定制浏览器 """ imp ...

  5. selenium&plus;python笔记7

    #!/usr/bin/env python # -*- coding: utf-8 -*- """ @desc: 测试126邮箱的登陆功能 1.使用公共方法public. ...

  6. selenium&plus;python笔记6

    #!/usr/bin/env python # -*- coding: utf-8 -*- """ @desc: 将登陆动作封装成function "&quot ...

  7. selenium&plus;python笔记5

    #!/usr/bin/env python # -*- coding: utf-8 -*- """ @desc: 登陆126邮箱 """ f ...

  8. selenium&plus;python笔记4

    #!/usr/bin/env python # -*- coding: utf-8 -*- """ @desc: 使用unittest组织用例 ""& ...

  9. selenium&plus;python笔记3

    #!/usr/bin/env python # -*- coding: utf-8 -*- """ @desc:学习unittest的用法 注意setUp/setUpCl ...

  10. selenium&plus;python笔记2

    #!/usr/bin/env python # -*- coding: utf-8 -*- """ @desc: 操作浏览器 """ fro ...

随机推荐

  1. linux终端指令总结

    一直没机会进行linux指令的系统学习,但是工作中总能遇到通过指令操作文件或数据库的情况,总不能一味地依赖后端开发者的帮忙.上任领导说过,要是在同一个地方跌倒,那么你就是*.我可不想成为*,so, ...

  2. spring&plus;ibatis&plus;多数据源

    环境:spring3.1+ibatis2.3.4+oracle+hbase要求:需要在工程中操作两个不同的数据源,一个是mssql,另一个是hbase.实现:    <bean id=&quot ...

  3. OpenResty&lpar;nginx&plus;lua&rpar; 入门

    OpenResty 官网:http://openresty.org/ OpenResty 是一个nginx和它的各种三方模块的一个打包而成的软件平台.最重要的一点是它将lua/luajit打包了进来, ...

  4. PIC32MZ tutorial -- Change Notification

    In my last post I implement "Key Debounce" with port polling, port polling is not very eff ...

  5. 20&plus;功能强大的jQuery&sol;CSS3图片特效插件

    以下是分享的20几个不错的图片特效插件,基于jQuery和CSS3. 1.jQuery图片下滑切换播放效果 这是一款基于jQuery的焦点图插件,这款焦点图的特点是有向下滑动的动画效果,滑到底部时,有 ...

  6. zzzzw&lowbar;在线考试系统①准备篇

    在弄完购物系统之后,小博也了解了解怎么用struts这个框架捣鼓一个在线考试系统 购物系统用的是MVC模式,现在这个struts2原理上也是基于MVC模式的.那么要做这个东西之前先了解一下难点在哪里 ...

  7. MySQL5&period;5 所支持的存储引擎

    本博文的主要内容有 .存储引擎的概念 .MySQL5.5 所支持的存储引擎 .操作默认存储引擎 .选择存储引擎 与其他的数据库软件不同,MySQL数据库软件提供了一个名为存储引擎的概念,由于存储引擎是 ...

  8. iOS系统原生 二维码的生成、扫描和读取(高清、彩色)

    由于近期工作中遇到了个需求:需要将一些固定的字段 在多个移动端进行相互传输,所以就想到了 二维码 这个神奇的东东! 现在的大街上.连个摊煎饼的大妈 都有自己的二维码来让大家进行扫码支付.可见现在的二维 ...

  9. 16进制到byte转换

    我们经常会看到这样的语法 (byte) 0xAD 0xAD实际是个16进制,转换成二进制为:10101101,转换成10进制是:173,它是个正数 10101101只是int的简写,int由4个byt ...

  10. 【NOIP 2017】逛公园

    Description 策策同学特别喜欢逛公园.公园可以看成一张N个点M条边构成的有向图,且没有 自环和重边.其中1号点是公园的入口,N号点是公园的出口,每条边有一个非负权值, 代表策策经过这条边所要 ...