Selenium webdriver 元素定位方法总结——转自优快云

原文作者给了很多例子,容易上手。

本文转自优快云,作者 我是6毛

原文链接如下:https://blog.youkuaiyun.com/lhyup/article/details/51800655


<input id="kw" class="s_ipt" autocomplete="off" maxlength="255" value="" name="wd"/>

<a class="mnav" name="test" href="http://news.baidu.com">新闻板块</a>

上面是百度输入框的代码

from selenium import webdriver

1. find_element_by_id("kw")

2. find_element_by_name("wd")

3. find_element_by_class_name("s_ipt")

4. find_element_by_tag_name("input")

5. find_element_by_link_text("新闻板块")

6. find_element_by_partial_link_text("新")

7.1 XPath-绝对路径定位:

绝对路径类似于你家的地址:XX市XX区XX路XX号;也就是说从最外层的标签开始往里数就可以了

例如百度输入框的绝对路径:

find_element_by_xpath("html/body/div[3]/div/div/div/div/form/span/input")

div[3] 代表当前层级第3个div

7.2 XPath-利用元素属性定位

find_element_by_xpath("//input[@id='kw']")

find_element_by_xpath("//input[@name='wd']")

find_element_by_xpath("//*[@id='kw']")

//input表示查找页面上所有的input元素

//*表示查找页面上所有元素

//input[1]表示查找页面上第一个input元素

//form[1]/input 表示查找第一个form元素下一级的input元素

//form[1]//input 表示查找页面上第一个form元素下的所有input元素,不管嵌套了多少层

//input[@id='kw' and @class='su'] 可以用 and 连接多个属性来唯一标识一个元素

Firepath可以生成XPath

8.css定位

find_element_by_css_selector("#kw")  #符号表示通过ID属性来定位元素

find_element_by_css_selector(".s_ipt")   点符号(.)表示通过class属性来定位元素

find_element_by_css_selector("input")    通过Tag标签来定位元素时不需要任何符号

find_element_by_css_selector("[id=kw]")  通过属性和属性值来定位元素,可以使用任意属性,例如 [type=submit]

find_element_by_css_selector(“span>input”)  通过父子关系定位元素

find_element_by_css_selector(“span+input”) 表示查找同一级紧挨着span的input元素

以上几种方式还可以综合使用

  

 

我个人喜欢用By定位元素

要使用By需要先import

from selenium.webdriver.common.by import By

1. find_element(By.ID,"kw")

2. find_element(By.NAME,"wd")

3. find_element(By.CLASS_NAME,"s_ipt")

4. find_element(By.TAG_NAME,"input")

5. find_element(By.LINK_TEXT,"新闻板块“)

6. find_element(By.PARTIAL_LINK_TEXT,"新”)

7. find_element(By.XPATH,"//*[@class='s_ipt']")

8. find_element(By.CSS_SELECTOR,“#kw”)
--------------------- 
作者:我是6毛 
来源:优快云 
原文:https://blog.youkuaiyun.com/lhyup/article/details/51800655 
版权声明:本文为博主原创文章,转载请附上博文链接!

Selenium中可以使用`move_to_element()`方法实现鼠标悬停操作。通过定位要悬停的元素,然后使用`ActionChains`类的`move_to_element()`方法将鼠标移动到该元素上即可。下面是一个示例代码,用于定位鼠标悬停出现的元素: ```python from selenium import webdriver from time import sleep from selenium.webdriver.common.action_chains import ActionChains driver = webdriver.Chrome() driver.get('https://www.example.com') menu = driver.find_element_by_css_selector("#menu-element") # 定位要悬停的元素 mouse = ActionChains(driver) mouse.move_to_element(menu).perform() # 将鼠标移动到指定元素上 sleep(2) # 等待悬停元素显示出来 # 继续定位悬停元素内的子元素并进行操作 sub_element = driver.find_element_by_css_selector("#sub-element") sub_element.click() driver.quit() ``` 在上述示例代码中,我们首先使用`driver.find_element_by_css_selector()`方法定位要悬停的元素。然后,通过`ActionChains`类的`move_to_element()`方法,将鼠标移动到该元素上。接着,我们可以继续定位悬停元素内的子元素,并执行相应的操作。最后,记得关闭浏览器驱动器。 注意:在使用鼠标悬停操作时,需要等待一段时间,确保悬停元素已经显示出来。可以使用`time.sleep()`方法添加等待时间。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [【Selenium学习】Selenium 中特殊元素操作](https://blog.csdn.net/weixin_73348410/article/details/129073467)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [处理Selenium3+python3定位鼠标悬停才显示的元素](https://download.csdn.net/download/weixin_38598613/12860942)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [selenium——定位鼠标悬停元素,获取悬浮框上的元素](https://blog.csdn.net/qq_37405087/article/details/116992837)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值