关于python中selenium获取不到跳转页面的元素问题解决

问题详述:

事情是这样式的,最近接收一个新项目做UI自动化,在编写脚本时发现登录定位不到登录成功页面的元素信息,尝试了各种定位方式都不行,最后发现因为页面是带js渲染的网页,所以根本就没加载登入成功的HTML代码!!哭晕在厕所。

虽然找到了原因,但想要解决在网上也是查询了各种方法,爬过了各种坑,最后终于找到一种解决方式,在此记录一下,方便以后查阅。

复制代码
# !/usr/bin/env python
# -*- coding: UTF-8 –*-
__author__ = 'Mr.Li'

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

driver = webdriver.Chrome()
driver.maximize_window()
driver.get('http://service.yunfuw.beta/login')

p = driver.find_element_by_xpath("//input[@class='el-input__inner']")
p.send_keys('xiaoming')
driver.find_element_by_xpath("//input[@placeholder='密码']").send_keys('admin1')
driver.find_element_by_xpath("//button[@class='el-button login-btn el-button--primary']").click()

#跳转到当前html页面,此时在进行定位就可以了
driver.switch_to.window(driver.window_handles[0])

html = driver.page_source
print(html)
复制代码

 注意:driver.switch_to.window(driver.window_handles[0])跳转时有可能句柄还为加载,最好在前面加一个sleep()等待

posted @   李荣洋  阅读(3356)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· C#/.NET/.NET Core技术前沿周刊 | 第 29 期(2025年3.1-3.9)
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
点击右上角即可分享
微信分享提示