selenium2 python学习笔记2---简单对象的定位

一系列元素定位方法:

1. id        find_element_by_id()

2. name   find_element_by_name()

3. class name   find_element _by_class_name()

4. tag name     find _element_by_tag_name()

//最不靠谱,相同tag name元素太多

5.link text        find_element_by_link_text()

//通过文字链接定位

6. partial link text    find_element_by_partial_link_text()

//通过文字链接的部分定位,简单有效

7. xpath    find_element_by_xpath()

//绝对目录与相对目录,可以做布尔逻辑运算,但存在明显缺点:(1)性能差,定位元素的性能要比其它大多数方式差;(2)不够健壮,XPath会随页面元素布局的改变而改变;(3)兼容性不好,不同浏览器下对XPath的实现是不一样的;

8. css selector   find_element_by_css_selector()

//使用选择器为元素绑定属性,选择器常见语法:

(1) *  ,通用元素选择器,匹配任何元素;

(2)E,标签选择器,匹配所有使用E标签的元素;

(3).info ,class选择器,匹配所有class属性中包含info的元素;

(4)#footer, id选择器,匹配所有id属性等于footer的元素;

(5)E,F,多元素选择器,同时匹配所有E元素或F元素,E和F之间用逗号分隔;

(6)E F,后代元素选择器,匹配所有属于E元素后代的F元素,E和F之间用逗号分隔;

(7)E>F ,子元素选择器,匹配所有E元素的子元素F;

(8)E+F, 毗邻元素选择器,匹配紧随E元素之后的同级元素F(只匹配第一个);

(9)E~F, 同级元素选择器,匹配所有在E元素之后的同级F元素;

(10)E[att = ‘val‘],属性att的值为val的E元素(区分大小写);

(11)E[att^ = ‘val‘],属性att的值以val开头的E元素(区分大小写);

(12)E[att $= ‘val‘],属性att的值以val结尾的E元素(区分大小写);

(13)E[att *= ‘val‘],属性att的值包含val的E元素(区分大小写);

(14)E[att 1= ‘val1‘][att 2*= ‘val2‘],属性att1的值为val1,att2的值包含val2(区分大小写);

(15)E:contains(‘xxx‘), 内容中包含XXX的E元素;

(16) E:not(s), 匹配不符合当前选择器的任何元素

时间: 2024-10-11 12:36:55

selenium2 python学习笔记2---简单对象的定位的相关文章

selenium2+python学习笔记(一)自动化测试环境的搭建

selenium2+python 自动化测试环境的搭建 1.准备工作 1.1.搭建平台:Windows 1.2.准备工具如下: 下载python:http://python.org/getit/ 下载setuptools[python的基础包工具]:http://pypi.python.org/pypi/setuptools 下载pip[python的安装包管理工具]:https://pypi.python.org/pypi/pip 下载selenium:https://pypi.python.

selenium2+python学习笔记(二)Python编辑器之Sublime

Sublime Text 是我发现的一款好用的编辑器,它不单单只支持Python,支持目前多种主流的编程语言,快捷键丰富,可以极大的提高代码开发效率.Sublime Text 网址:http://www.sublimetext.com/ 版本选择:对于Python,Sublime Text 3 对于Sublime Text 2 的区别在于其更新了Python的函数,API不同了,不过ST2 相对于ST3 来说更加稳定. 本文中例子采用编辑器为ST2 1 安装Python相关插件 1.1 安装Pa

Selenium2 Python 学习笔记1---浏览器版本匹配

最近开始学习selenium,按照书上编写一个自动化脚本: from selenium import webdriver browser = webdriver.Firefox browser.get("http://www.baidu.com") browser.find_element_by_id("kw").send_keys("selenium") browser.find_element_by_id("su").cl

selenium2 python 学习笔记--xpath模糊匹配

xpath模糊匹配,类似find_by_partial_link,如下图: contains(属性名,字符串),starts-with(属性名,字符串),ends-with(属性名,字符串),matchs(属性名,字符串)

OpenCV之Python学习笔记

OpenCV之Python学习笔记 直都在用Python+OpenCV做一些算法的原型.本来想留下发布一些文章的,可是整理一下就有点无奈了,都是写零散不成系统的小片段.现在看 到一本国外的新书<OpenCV Computer Vision with Python>,于是就看一遍,顺便把自己掌握的东西整合一下,写成学习笔记了.更需要的朋友参考. 阅读须知: 本文不是纯粹的译文,只是比较贴近原文的笔记:         请设法购买到出版社出版的书,支持正版. 从书名就能看出来本书是介绍在Pytho

Python学习笔记--未经排版

Python 学习笔记 Python中如何做到Print() 不换行 答:Print("输出内容",end='不换行的分隔内容'),其中end=后面为2个单引号 注:在Python 2.x中,Print "输出内容", 即在输出内容后加一逗号 Python中 is 和 == 的区别 答:Python中的对象包含三要素:id.type.value 其中id用来唯一标识一个对象,type标识对象的类型,value是对象的值 is判断的是a对象是否就是b对象,是通过id来

Python学习笔记一简介及安装配置

Python学习笔记一 参考教程:廖雪峰官网https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000 一.Python简介 Python是著名的"龟叔"Guido van Rossum在1989年圣诞节期间,为了打发无聊的圣诞节而编写的一个编程语言.龟叔给Python的定位是"优雅"."明确"."简单". Python

python学习笔记12-模块使用

python学习笔记12-模块使用 模块os,sys 什么是模块? 模块os,sys 模块是Python组织代码的一种基本方式 一个Python脚本可以单独运行,也可以导入到另外一个脚本运行,用import hello语句来导入,不用加入.py 什么是Python的 包? Python的模块可以按照目录组织为包 创建一个包的步骤: 创建一个名字为包名的目录 在改目录下创建一个__init__.py文件 根据需要,在该目录下存放脚本文件或已编译的扩展及子包 import pack.m1,pack.

python学习笔记2—python文件类型、变量、数值、字符串、元组、列表、字典

python学习笔记2--python文件类型.变量.数值.字符串.元组.列表.字典 一.Python文件类型 1.源代码 python源代码文件以.py为扩展名,由pyton程序解释,不需要编译 [[email protected] day01]# vim 1.py #!/usr/bin/python        print 'hello world!' [[email protected] day01]# python 1.py hello world! 2.字节代码 Python源码文件