selenium——定位鼠标悬停元素,获取悬浮框上的元素

应用场景:小米商城首页,鼠标悬停在“小米手机”后,获取悬浮框页面上的元素

from selenium import webdriver
from time import sleep
from selenium.webdriver.common.action_chains import ActionChains

driver = webdriver.Chrome()
driver.maximize_window()
driver.get('https://www.mi.com/index.html')

sleep(2)
# 定位鼠标悬停元素
# el = driver.find_element_by_xpath('//*[@data-log_code="31pchomeother001000#t=normal&act=other&page=home&page_id=10530&bid=3476901.1"]')
el = driver.find_element_by_css_selector('[data-index="0"]')  
ActionChains(driver).move_to_element(el).perform()  # 鼠标悬停
sleep(1)
driver.find_element_by_xpath('//*[@id="J_navMenu"]//ul[@class="children-list clearfix"]')  # 定位弹框上的元素

sleep(5)
driver.quit()

 

另外一种方法,参考学习:

from selenium import webdriver
from time import sleep
from selenium.webdriver.common.action_chains import ActionChains

driver = webdriver.Chrome()
# driver.maximize_window()
driver.get('https://www.mi.com/index.html')

# 模拟鼠标悬停操作
menu = driver.find_element_by_css_selector("#J_navCategory+li") # 定位鼠标要悬停的元素
mouse = ActionChains(driver)
mouse.move_to_element(menu).perform()  # 鼠标悬停到定位元素上
sleep(5)   # 页面跳转时间

# 获取弹框页面上产品名称
items = driver.find_elements_by_css_selector("#J_navMenu .title")  # 同时定位多个元素,所以必须用find_elements
titles = []
for item in items:
    titles.append(item.text)
# print(titles)
assert titles == ['小米MIX FOLD', '小米11 Ultra', '小米11 Pro', '小米11 青春版', '小米10S', '小米11']
driver.quit()
  • 4
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
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 ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值