Splinter入门(三) Finding Elements 查找元素
Splinter入门(三) Finding Elements 查找元素
查找Elements
Splinter提供了六种查找html元素的API,包括css
, xpath
, tag
, name
, id
, value
, text
:
browser.find_by_css('h1')
browser.find_by_xpath('//h1')
browser.find_by_tag('h1')
browser.find_by_name('name')
browser.find_by_text('Hello World!')
browser.find_by_id('firstheader')
browser.find_by_value('query')
获取Elements
这些方法中的每一个都返回一个包含查找元素的列表。获取列表的元素可以使用:
first_found = browser.find_by_name('name').first # 第一个节点
last_found = browser.find_by_name('name').last # 最后一个节点
second_found = browser.find_by_name('name')[1] # 获取索引为1的节点
find_by_id使用注意事项
网页的每个元素只有一个唯一id,所以find_by_id方法总是返回一个只有一个元素的列表。
Finding links
有时候,可能只关注含有连接links的元素,因此,在Splinter中,提供了links 命名空间,其下有多个方法可以查找元素。
links_found = browser.links.find_by_text('Link for Example.com') # 通过Text查找(全匹配)(这里的text指的是a标签内的Text)
links_found = browser.links.find_by_partial_text('for Example') # 通过Text查找(部分匹配)(这里的text指的是a标签内的Text)
links_found = browser.links.find_by_href('http://example.com') # 通过链接查找(全匹配)
links_found = browser.links.find_by_partial_href('example') # 通过链接查找(部分匹配)links_found = browser.find_by_css('.main').links.find_by_text('Link for Example.com')
links_found = browser.find_by_css('.main').links.find_by_partial_text('for Example.com')
links_found = browser.find_by_css('.main').links.find_by_href('http://example.com')
links_found = browser.find_by_css('.main').links.find_by_partial_href('example')
以上的find_*
方法均返回一个列表。可以看出,links
适用适用于browser
对象以及elements
。
链式查找Elements
Splinter支持链式查找元素:
divs = browser.find_by_tag("div") # 找到所有div
within_elements = divs.first.find_by_name("name") # 获取第一个div下的name为“name”的元素
元素不存在异常 ElementDoesNotExist
exception
如果找不到一个元素,那么find_*方法将返回一个空列表。但是,如果试图访问此列表中的一个元素,则该方法将引发plinter.Exctions.ElementDoesNotExist
异常。
Splinter入门(三) Finding Elements 查找元素相关推荐
- Splinter入门(七) Interacting with elements 元素交互(二)
Splinter入门(七) Interacting with elements 元素交互(二) API说明 Splinter提供了系列操作表单组件的API. 函数 说明 注释 browser.fil ...
- Splinter 查找元素
通常的查找元素方法 browser.find_by_css('h1') browser.find_by_xpath('//h1') browser.find_by_tag('h1') browser. ...
- Splinter入门(六) links的API
Splinter入门(六) links的API (查找链接)Finding links 有时候,可能只关注含有连接links的元素,因此,在Splinter中,提供了links 命名空间,其下有多个 ...
- Jsoup使用选择器语法来查找元素
如果你想使用类似于CSS或jQuery的语法来查找和操作元素,我们可以使用Element.select(String selector) 和 Elements.select(String select ...
- CSS入门二、美化页面元素
零.文章目录 CSS入门二.美化页面元素 1.字体属性 CSS Fonts (字体)属性用于定义字体系列.大小.粗细.和文字样式(如斜体) (1)字体系列font-family font-family ...
- Python实现网页自动化-浏览器查找元素(二)
前言 在上一节中已经部署了Selenium+chromedriver的开发环境,在真正的开发之前,还需要学会利用浏览器来查找网页元素: 因为Selenium是通过程序来自动操控网页的控件元素,比如单击 ...
- DOM(一)概述、dom树、查找元素
目录 一.DOM 概述 二.DOM树 二.查找元素 1. 无需查找的元素 2. 按节点间关系查找 3. 按 HTML 特征查找 三.案例:通过DOM实现购物车效果 一.DOM 概述 DOM全称 Doc ...
- 脑残式网络编程入门(三):HTTP协议必知必会的一些知识
为什么80%的码农都做不了架构师?>>> 本文原作者:"竹千代",原文由"玉刚说"写作平台提供写作赞助,原文版权归"玉刚说&q ...
- 使用选择器语法查找元素——Selector选择器概述 ——未完待续
使用选择器语法查找元素 jsoup elements对象支持类似于CSS (或jquery)的选择器语法,来实现非常强大和灵活的查找功能. select 方法在Document, Element,或E ...
最新文章
- 在Lumen中引入钉钉SDK
- android实现多画面播放,可无缝切换小窗/全屏的android播放器实现
- Linux2.6 --系统调用处理程序
- 技术生涯二三事(上)
- java 线程执行完就会回收吗_Java线程池技术Executors的这个坑你踩过吗?
- python (第八章)补充-可迭代对象(补充高阶函数,以及常用的高阶函数)
- python进程池一个进程卡住_python进程池,每个进程都有超时
- 【算法设计】最大子段和问题解析(对应算法第三题)
- adb ps shell 查看进程_Appium学废系列(三) adb调试桥命令
- ssh 多台服务器之间连接(linux)
- java 本地文件路径怎么写_java本地文件路径怎么写
- Docker镜像下载到本地及恢复
- linux zip分卷压缩解压命令
- L3-001 凑零钱 (30 分)——01背包+路径记录
- win10系统更新遇到 “我们无法完成更新,正在撤销更改“ 解决办法
- Commands that may modify the data set are disabled, because this instance is configured to report er
- Java 用Freemarker完美导出word文档(带图片)
- java拼图游戏系统总体方案_基于JAVA的拼图游戏的设计与实现(含录像)
- UOJ#311. 【UNR #2】积劳成疾 动态规划
- 【JUC】什么是ABA问题?
热门文章
- C++实现计算器(四则混合运算)
- bzoj2085 [Poi2010]Hamsters 哈希+倍增
- 计算机账户和用户账户区别,网络操作系统第四章用户和计算机帐户习题及答案...
- Codeforces Round #462 (Div. 1) A Twisty Movement -12序列的LIS
- java设置全局变量_java中如何实现全局变量
- c语言下标法改为指针变量法,C语言指针教学的改革探析.doc
- 来看看今天推荐的好用软件吧
- 项目经理年终总结报告模板
- Capturing Omni-Range Context for Omnidirectional Segmentation总结笔记
- 红米K20 Pro 传感器失效解决方案