关于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()等待

原文地址:https://www.cnblogs.com/lirongyang/p/12651634.html