'''
网易云音乐实现QQ登录
'''
# 通过link text进行元素定位,用于定位超链接(a标签),通过a标签文本来实现定位
# el = driver.find_element_by_link_text('学术').click
# 导入
from time import sleep
from selenium import webdriver
# 打开浏览器
driver = webdriver.Chrome()
# url访问
driver.get('https://music.163.com/')
sleep(3)
driver.maximize_window()
# 点击‘登录’按钮
driver.find_element_by_link_text('登录').click()
# 点击‘选择其他登录模式’
driver.find_element_by_link_text('选择其他登录模式').click()
# 点击‘同意’
driver.find_element_by_id('j-official-terms').click()
# 点击‘QQ登录’
driver.find_element_by_link_text('QQ登录').click()
sleep(3)
# 句柄的处理
'''
这里跳转到其他页面,涉及句柄的切换
在计算机世界中,不同的标签页,是通过不同的字符串来区分。可以理解为id,统一称之为句柄
如果要操作心得句柄页,切换句柄就可以了
原则:
1.在selenium自动化时,尽可能保持有,切最多仅有两个页面存在
2.如果页面会自行关闭,就不需要额外执行close(特定业务)
3.如果自动关闭后,仍需要操作其他页面,则需要切换句柄
'''
# 切换句柄
handles = driver.window_handles # 获取当前所有的句柄
# driver.close() # 关闭当前句柄页
driver.switch_to.window(handles[1]) # 切换到第二个句柄页
# print(handles)
sleep(3)
# 跳转到QQ登录页面,操作第二个句柄页
# driver.find_element('link text', 'QQ登录').click()
# print(driver.title)
# driver.find_element_by_id('img_out_1369595841').click()
# handles = driver.window_handles
# print(handles)
'''
这里定位时,输入driver.find_element_by_id('img_out_1369595841').click()
并没有找到该元素定位,是因为这里遇到了iframe窗体
iframe是一个窗体,内嵌页面,本身是一个独立的HTML页面存在,本质上是套娃
对于iframe内的元素如果要操作,是没有办法直接定位的
当遇到死活定位不到的元素,检查一下是不是一个iframe,是的话,则切换iframe后在操作
iframe再切换进去之后,就只可以操作iframe中的内容,iframe意外的内容无法操作,
如果要操作原窗体内容,需要重新返回默认窗体
driver.switch_to.default_content()
'''
# 切换iframe:有id就直接传入ID即可,没有id,就通过元素定位,传递元素进去
frame = driver.find_element('id', 'ptlogin_iframe')
driver.switch_to.frame(frame)
# 进行QQ登录
driver.find_element('id', 'img_out_1369595841').click()
sleep(2)
# 返回默认窗体,相当于回到原窗体
# driver.switch_to.default_content()
handles = driver.window_handles
print(handles)
driver.switch_to.window(handles[0])
print(driver.title)
sleep(3)
driver.quit()
|