博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
selenium python 一些操作和定位收集
阅读量:6942 次
发布时间:2019-06-27

本文共 5252 字,大约阅读时间需要 17 分钟。

(—)滚动条操作

#(1)使用JS操作浏览器(右侧竖向)滚动条time.sleep(3)#最好等个几秒#将滚动条移动到页面的顶部 js="var q=document.documentElement.scrollTop=0"driver.execute_script(js)#页面内嵌窗口浏览条滚动js="var q=document.getElementById('id').scrollTop=1000"driver.execute_script(js)time.sleep(3)# 通过按向下键将页面滚动条拖到底部 driver.find_element_by_xpath("xpath").send_keys(Keys.DOWN)#(2)使用JS操作浏览器(底部横向)滚动条#这个是全页面的js = "window.scrollTo(210,550);" #(x, y)x:代表横向坐标y:代表纵向坐标#(3)当我们需要定位的元素是动态元素,或者我们不确定它在哪时,可以先找到这个元素然后再使用JS操作target = driver.find_element_by_id('id')driver.execute_script("arguments[0].scrollIntoView();", target)

 

 

 

使用xpath解决一切复杂的定位。

find_element_by_xpath("//span[text()='APPRMIN']")find_elements_by_xxx 会返回一个所有符合条件的element组成的列表,通过element.text属性获取文本texts = list(ele.text for ele in find_elements_by_xpath("//span[@class='tree_title']"))

 

 

======以下是Select定位==== 

1、Select元素

1.打开百度-设置-搜索设置界面,如下图所示

2.箭头所指位置,就是 select 选项框,打开页面元素定位,下方红色框框区域,可以看到 select 标签属性:

<select id="nr" name="NR">

3.选项有三个
<option selected="" value="10">每页显示 10 条</option>
<option value="20">每页显示 20 条</option>
<option value="50">每页显示 50 条</option>

2、定位select

定位select有多种方法,下面进行一一介绍

2.1 二次定位

1.定位 select 里的选项有多种方式,这里先介绍一种简单的方法:二次定位

2.基本思路,先定位 select 框,再定位 select 里的选项

完整代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# coding:utf-8
from 
selenium 
import 
webdriver
from 
selenium.webdriver.common.action_chains 
import 
ActionChains
 
driver 
= 
webdriver.Firefox()
driver.get(
"https://www.baidu.com/"
)
driver.implicitly_wait(
20
)
 
mouse 
= 
driver.find_element_by_link_text(
"设置"
)
ActionChains(driver).move_to_element(mouse).perform()
driver.find_element_by_link_text(
"搜索设置"
).click()
= 
driver.find_element_by_id(
"nr"
)
s.find_element_by_xpath(
"//option[@value='50']"
).click()
# 二次定位另外一种写法
driver.find_element_by_id(
"nr"
).find_element_by_xpath(
"//option[@value='50']"
).click()

3.还有另外一种写法也是可以的,把最下面两步合并成为一步:

driver.find_element_by_id("nr").find_element_by_xpath("//option[@value='50']").click()

 2.2 直接定位

1.有很多小伙伴说 firebug 只能定位到 select 框,还能定位里面的选项。

2.用 direbug 定位到 select 后,下方查看元素属性地方,点 select 标签前面的+号,就可以展开里面的选项内容了。

3.然后自己写 xpath 定位或者 css,一次性直接定位到 option 上的内容。

  完整代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
# coding:utf-8
from 
selenium 
import 
webdriver
from 
selenium.webdriver.common.action_chains 
import 
ActionChains
 
driver 
= 
webdriver.Firefox()
driver.get(
"https://www.baidu.com/"
)
driver.implicitly_wait(
20
)
 
mouse 
= 
driver.find_element_by_link_text(
"设置"
)
ActionChains(driver).move_to_element(mouse).perform()
driver.find_element_by_link_text(
"搜索设置"
).click()
# 直接点位
driver.find_element_by_xpath(
".//*[@id='nr']/option[2]"
).click()

2.3  Select  模块(index)点位  

1.除了上面介绍的两种简单的方法定位到 select 选项,selenium 还提供了更高级的玩法,导入 Select 模块。直接根据属性或索引定位。

2.先要导入 select 方法:
from selenium.webdriver.support.select import Select
3.然后通过 select 选项的索引来定位选择对应选项(从 0 开始计数),如选择第三个选项:select_by_index(2)
   完整代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# coding:utf-8
from 
selenium 
import 
webdriver
from 
selenium.webdriver.common.action_chains 
import 
ActionChains
from 
selenium.webdriver.support.select 
import 
Select
 
driver 
= 
webdriver.Firefox()
driver.get(
"https://www.baidu.com/"
)
driver.implicitly_wait(
20
)
 
mouse 
= 
driver.find_element_by_link_text(
"设置"
)
ActionChains(driver).move_to_element(mouse).perform()
driver.find_element_by_link_text(
"搜索设置"
).click()
# 通过索引:select_by_index()
= 
driver.find_element_by_id(
"nr"
)
Select(s).select_by_index(
2
)

 2.4 Select  模块(value)定位

1.Select 模块里面除了 index 的方法,还有一个方法,通过选项的 value值来定位。每个选项,都有对应的 value 值,如

<select id="nr" name="NR">
<option selected="" value="10">每页显示 10 条</option>
<option value="20">每页显示 20 条</option>
<option value="50">每页显示 50 条</option>
2.第二个选项对应的 value 值就是“20”:select_by_value(2)

  完整代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# coding:utf-8
from 
selenium 
import 
webdriver
from 
selenium.webdriver.common.action_chains 
import 
ActionChains
from 
selenium.webdriver.support.select 
import 
Select
 
driver 
= 
webdriver.Firefox()
driver.get(
"https://www.baidu.com/"
)
driver.implicitly_wait(
20
)
 
mouse 
= 
driver.find_element_by_link_text(
"设置"
)
ActionChains(driver).move_to_element(mouse).perform()
driver.find_element_by_link_text(
"搜索设置"
).click()
# 通过value定位:select_by_value()
= 
driver.find_element_by_id(
"nr"
)
Select(s).select_by_value(
20
)

2.5  Select  模块(text)定位

1.Select 模块里面还有一个更加高级的功能,可以直接通过选项的文本内容来定位。

2.定位“每页显示 50 条”:select_by_visible_text("每页显示 50 条")

  完整代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# coding:utf-8
from 
selenium 
import 
webdriver
from 
selenium.webdriver.common.action_chains 
import 
ActionChains
from 
selenium.webdriver.support.select 
import 
Select
 
driver 
= 
webdriver.Firefox()
driver.get(
"https://www.baidu.com/"
)
driver.implicitly_wait(
20
)
 
mouse 
= 
driver.find_element_by_link_text(
"设置"
)
ActionChains(driver).move_to_element(mouse).perform()
driver.find_element_by_link_text(
"搜索设置"
).click()
# 通过select_by_visible_text定位
= 
driver.find_element_by_id(
"nr"
)
Select(s).select_by_visible_text(
"每页显示50条"
)

3.Select  模块其它方法

1.select 里面方法除了上面介绍的三种,还有更多的功能如下

select_by_index() :通过索引定位

select_by_value() :通过 value 值定位
select_by_visible_text() :通过文本值定位
deselect_all() :取消所有选项
deselect_by_index() :取消对应 index 选项
deselect_by_value() :取消对应 value 选项
deselect_by_visible_text() :取消对应文本选项
first_selected_option() :返回第一个选项
all_selected_options() :返回所有的选项

 
 
 
 
 
 
 
 

转载于:https://www.cnblogs.com/mapu/p/9014318.html

你可能感兴趣的文章
Git常用命令
查看>>
自开发Web应用和SAP Customer Data Cloud Identity服务的集成
查看>>
HanLP Android 示例
查看>>
推荐四十多条纯干货 Java 代码优化建议
查看>>
「镁客·请讲」太平洋未来科技李建亿:深耕AR技术,布局垂直领域
查看>>
如何用纯 CSS 创作一种侧立图书的特效
查看>>
中软酒店管理系统CSHIS操作手册_数据结构_数据字典
查看>>
跳出弹窗页面禁止滚动(PC端和手机端)
查看>>
HTML5/CSS3鼠标悬停动画菜单按钮
查看>>
Android Studio打包错误(Cannot merge new index 67578 into a non-jumbo instruction!)
查看>>
SLS机器学习介绍(03):时序异常检测建模
查看>>
4.1ASP.NET Core请求过程「深入浅出ASP.NET Core系列」
查看>>
安装elasticsearch中文切词插件hanlp
查看>>
Redis 的 KEYS 命令引起 RDS 数据库雪崩,宕机 2 次,造成几百万损失
查看>>
点播转码相关常见问题及排查方式
查看>>
gc.collect()清内存
查看>>
如何在HTTPS里调用HTTP资源不出现提示框
查看>>
Jenkins 2.173 发布,开源持续集成引擎
查看>>
《文科生数据科学上手指南》分享
查看>>
PostgreSQL json 索引实践 - 检索(存在、包含、等值、范围等)加速
查看>>