Xpath选择、操作web元素

时间:2021-10-19 00:02:41

11月6日

xpath选择

XPath(XML Path Language)是W3C(World Wide Web Consortium)定义的用来在XML文档中选择节点的语言,

主浏览器也支持XPath语法(1.X),对于浏览器原生支持XPath的,Selenium尽量使用原生的XPath实现,有些浏览器也支持通过XPath来访问。xpath的语法 看起来非常像电脑文件系统的路径

xpath验证方法     //option

console中                $x('//option')

element tab中

根节点:根节点用 / 表示:对应整个html文档   $x('/')

  /html -对应html节点

  /html/body/div 继续选择html下面的一层层节点                                find_elements_by_xpath('/html/body/div')

  假如路径起始于正斜杠(/),则此路径始终代表到某元素的绝对路径

  / 符号比较像css 中的 > 符号                    直接子元素

//符号的作用

选择整个文档中的所有的option节点,不管什么位置

当前节点 一开始,我们的当前节点就是根节点,通常html      随后,路径当前部分就是当前节点,比如 /html/body/span

//表示从当前节点寻找所有的后代元素,寻找所有的后代元素,不管它在什么位置

  如果以//开头就表示从根节点开始,寻找所有的后代元素

  //div//p 表示选择所有的div元素里面的p元素,不管div在什么位置,不管p元素在div下面的什么位置     $x('//div//p')        <==>            $$('div  p')    ,单斜杠表示直接子节点,双斜杠表示后代

  //div/p 就等于css选择器的什么写法?      $x('//div/p')         <==>   $$('div >p')   直接子节点

通配符 和css一样,xpath也有通配符 *

  //div/* 选择div下面所有的元素   等价于css $$('div > *')

根据属性选择

  //*[@style] 选择所有具有style属性元素             *style

  //p[@spec='len2'] 选择所有具有spec 值为len2 的元素    注意:css中如果属性值,如果没有空格可以不加引号,但是xpath则必须要引号,单双引号都可以                p[spec='len2']

根据id选择:id、class也是属性    //*[@id="food"]     //div[@id="food"]   //div[@class="cheese"]

子元素选择

选择属于其父元素的第n个某个类型的子元素

  //p[2]等价于 p:nth-of-type(2)

  //*[@id="food"]/p[1] 等价于 #food > p:nth-of-type(1)

  //*2  所有类型的第二个

选择属于其父元素的倒数第n个某个类型的子元素

  //span[last() -1] 属于其父元素的倒数第二个span              span:nth-last-of-type(2)

  //*[@id ="food"]/span[last()]

  //*[last()-1]

选择属于其父元素的第n个子元素(基本所有类型元素)

  //*[2] 等价于 //*[position()=2] 等价于 *:nth-child(2)

  //*[@id = "food"]/*[position()=3]

支持其他的比较操作符

  //*[@id = "food"]/*[position() < 3]             前两个

  //*[@id = "food"]/*[position() <= 3]           前三个

选择属于其父元素的倒数第n个子元素

  //*[@id = "food"]/*[last()-1]等价于//*[@id ="food"]/*[position()=last()-1]

  多选 //*[@id = "food"]/*[position() > last() -3]     后面三个

组选择

用多个表达式一起

css 用,隔开

比如p,button

Xpath用 | 隔开

//p | //button

其他选择语法

参考 http://www.w3school.com.cn/xpath/xpath_axes.asp

相邻兄弟选择器

  following-sibling  后面的兄弟     css:   #food ~ div 《=》xpath: //*[@id = "food"]/following-sibling::div

#food +div 紧跟着的兄弟

  preceding-sibling

xpath 擅长的 选择父节点  ..符号,position函数,结合比较操作符

//*[@id = "food"]/..

food = driver.find_element_by_xpath("//*[@id = 'food']")

eles = food.find_elements_by_xpath('.//p)  这里要加一个点,表示当前的food

for ele in eles:

  print('..........................')

  print(ele.get_attribute('outerHTML'))

Selenium 作业 4

登录 http://www.51job.com
点击高级搜索
输入搜索关键词 python
地区选择 杭州
职能类别 选 计算机软件 -> 高级软件工程师
公司性质选 外资 欧美
工作年限选 1-3 年 搜索最新发布的职位, 抓取页面信息。 得到如下的格式化信息 Python开发工程师 | 杭州纳帕科技有限公司 | 杭州 | 0.8-1.6万/月 | 04-27
Python高级开发工程师 | 中浙信科技咨询有限公司 | 杭州 | 1-1.5万/月 | 04-27

参考答案,往下翻

# coding:utf8
from selenium import webdriver
executable_path = r"d:\tools\webdrivers\chromedriver.exe" driver = webdriver.Chrome(executable_path)
driver.implicitly_wait(10) # 打开网址
driver.get('http://www.51job.com') # 选择高级搜索
driver.find_element_by_css_selector('div.ush > a').click() # 输入选择关键词
driver.find_element_by_id('kwdselectid').send_keys('python') # 工作地点选择
driver.find_element_by_id('work_position_input').click() # 取消 已经选择的
selectedCityEles = driver.find_elements_by_css_selector('#work_position_click_center em[class=on]') for one in selectedCityEles:
one.click() # 选杭州
driver.find_element_by_id('work_position_click_center_right_list_category_000000_080200').click() # 保存选择
driver.find_element_by_id('work_position_click_bottom_save').click() # 要点一下别的地方, 否则下面的元素会被挡住
driver.find_element_by_css_selector('div.tit').click() # 职能类别 选 计算机软件 -> 高级软件工程师 driver.find_element_by_id('funtype_click').click() driver.find_element_by_id('funtype_click_center_right_list_category_0100_0100').click() driver.find_element_by_id('funtype_click_center_right_list_sub_category_each_0100_0106').click() driver.find_element_by_id('funtype_click_bottom_save').click() # 公司性质选 外资 欧美
driver.find_element_by_id('cottype_list').click()
driver.find_element_by_css_selector('#cottype_list span.li[data-value="01"]').click() # 工作年限选
driver.find_element_by_id('workyear_list').click()
driver.find_element_by_css_selector('#workyear_list span.li[data-value="02"]').click() # 点击搜索
driver.find_element_by_css_selector('div.p_sou > span.p_but').click()或者 driver.find_element_by_css_selector("span.p_but[onclick^='kwdGoSearch']").click() # 结果列表获取内容
jobs = driver.find_elements_by_css_selector('#resultList div[class=el]') for job in jobs:
fields = job.find_elements_by_tag_name('span')
stringFilelds = [field.text for field in fields]
print (' | '.join(stringFilelds)) driver.quit()

Xpath选择、操作web元素的更多相关文章

  1. 选择、操作web元素-2

    11月3日 等待web元素的出现 例子:百度搜索松勤网,点击操作后不等待页面刷新,下面选择页面元素的时候,该元素还是未出现 sleep方案的弊病:固定的等待时间,导致测试用例执行时间很长 为什么cli ...

  2. 选择、操作web元素

    11月1日 什么是web元素 Selenium自动化主要就是:选择界面元素,操作界面元素(输入操作:点击.输入文字.拖拽等,输出操作:获取元素的各种属性),根据界面上获取的数据进行分析和处理 选择元素 ...

  3. 选择、操作web元素-3

    11月5日 Selenium 作业 3 登录 51job , http://www.51job.com 输入搜索关键词 "python", 地区选择 "杭州"( ...

  4. Web自动化 - 选择操作元素 1

    文章转自 白月黑羽教Python 所有的 UI (用户界面)操作 的自动化,都需要选择界面元素. 选择界面元素就是:先让程序能找到你要操作的界面元素. 先找到元素,才能操作元素. 选择元素的方法 程序 ...

  5. Web自动化 - 选择操作元素 2

    文章转自 白月黑羽教Python 前面我们看到了根据 id.class属性.tag名 选择元素. 如果我们要选择的 元素 没有id.class 属性, 这时候我们通常可以通过 CSS selector ...

  6. selenium怎么操作web页面常见的元素

    总结一下selenium怎么操作web页面常见的元素. 主要有: 上传 alter dialog prompt dialog confirm dialog select list radio box ...

  7. Appium之选择&sol;操作元素

    Appium是如何选择.操作元素的呢? appium自动化  ------  选择界面 元素 操作元素  ------- ① 点击 ② 输入字符 ③ 拖拽 ④ 获取页面元素的各种属性 根据appium ...

  8. 基于MVC4&plus;EasyUI的Web开发框架经验总结(14)--自动生成图标样式文件和图标的选择操作

    在很多Web系统中,一般都可能提供一些图标的选择,方便配置按钮,菜单等界面元素的图标,从而是Web系统界面看起来更加美观和协调.但是在系统中一般内置的图标样式相对比较有限,而且硬编码写到样式表里面,这 ...

  9. Selenium选择web元素

    获取html片段可以用来做什么? 可以用来分割,也可以分析HTML文档 beautifulsoup用法? 安装beautifulsoup库: pip install beautifulsoup4 因为 ...

随机推荐

  1. Error&colon;const char&ast; 类型的实参和LPCWSTR类型的形参不兼容的解决方法。

    在C++的Windows 应用程序中经常碰到这种情况. 解决方法: 加入如下转换函数: LPCWSTR stringToLPCWSTR(std::string orig) { size_t origs ...

  2. excle表格生成网页

    用Dreamweaver可以方便生成和excle表格一样的代码. 复制excle,粘贴

  3. bzoj3405:&lbrack;Usaco2009 Open&rsqb;Grazing2 移动牛棚

    思路:首先因为要让距离尽量大,所以奶牛1一定在1号牛棚,奶牛n一定在s号牛棚,然后考虑dp. 因为总距离为s-1,然后要使长度为d的段数尽量多,那么剩下的一定就是d+1的段数,也就是s-(n-1)*d ...

  4. 【mysql的设计与优化专题&lpar;2&rpar;】数据中设计中的范式与反范式

    设计关系数据库时,遵从不同的规范要求,设计出合理的关系型数据库,这些不同的规范要求被称为不同的范式,各种范式呈递次规范,越高的范式数据库冗余越小.但是有些时候一昧的追求范式减少冗余,反而会降低数据读写 ...

  5. SDL&lowbar;Test库&lpar;1&rpar;——SDL不用TTF库绘制文字

    SDL库有很多的扩展,这很方便.但是每个扩展库都很臃肿,一般都会拖上额外的两三个开源库,更有甚者,扩展库的大小比SDL库本身还大得多.但有一个自带的.很有用的库很容易被大家忽视.它就是本文要讲的SDL ...

  6. mysql shutdown and kill

    --mysqladmin shutdown If you execute mysqladmin shutdown when connecting to a local server using a U ...

  7. centos7下固定IP(静态IP)网络配置

    关于centos下网络配置(这里使用静态IP方法) 动态ip网络配置可参考我的另一篇博文http://www.cnblogs.com/albertrui/p/7811868.html 1.编辑/etc ...

  8. 教你一步步发布一个开源库到 JCenter

    今天想来分享下,如何一步步自己发布一个开源库到 JCenter 这方面的博客网上已经特别多了,所以本篇并不打算仅仅只是记录流程步骤而已,而是尽可能讲清楚,为什么需要有这个步骤,让大伙知其然的同时还知其 ...

  9. Unity Input&comma;生命周期,Light,获取组件

    1.     递归方法遍历获取指定子物体 知识点:递归的使用:transform.childCount.GetChild(index) 2.  Input输入控制类,检测玩家输入 知识点: Input ...

  10. vue cli3 vue&period;config&period;js 配置详情

    module.exports = {   // 基本路径   baseUrl: process.env.NODE_ENV === 'production'     ? '/'     : '/',   ...