python网络爬虫selenium打开多窗口与切换页面的实现
程序员文章站
2022-06-17 20:38:55
关于python网络爬虫selenium打开多窗口与切换页面的方法代码测试与解析。首先打开百度from selenium import webdriverimport timedriver = web...
关于python网络爬虫selenium打开多窗口与切换页面的方法代码测试与解析。
首先打开百度
from selenium import webdriver import time driver = webdriver.chrome() driver.get('https://www.baidu.com/')
以知乎为例,打开一个新的界面,使用 execute_script() 方法,执行javascript代码。
并调用driver的current_url属性,然后查看当前页面的url:
driver.execute_script("window.open('https://www.zhihu.com')") print(driver.current_url)
当前页面依然还是百度。要想把当前页面换成知乎,还需要继续用代码切换过来。
打印 句柄 ,即driver的 window_handles 属性,输出结果如下:
print(driver.window_handles)
是一个有两个元素的列表,分别代表上边打开的两个网页,百度和知乎。
分别将其传入switch_to.window()方法中,再打印当前页面的url,输出结果如下,可以看到,页面成功被切换。
win1 = driver.window_handles[0] driver.switch_to.window(win1) print(driver.current_url) time.sleep(2) win2 = driver.window_handles[1] driver.switch_to.window(win2) print(driver.current_url)
关于句柄在列表中的顺序,
建议一般最好只额外打开一个网页,不建议打开更多的网页进行切换。当打开的网页数量超过两个时,句柄列表中的元素分别代表哪个网页,其顺序是不太好确定的。以下面代码为例,其顺序如下。
from selenium import webdriver import time driver = webdriver.chrome() driver.get('https://www.baidu.com/') # 打开一个新的页面 driver.execute_script("window.open('https://www.zhihu.com')") driver.execute_script("window.open('https://www.lagou.com/')") driver.execute_script("window.open('https://www.jianshu.com/')") win1 = driver.window_handles[0] driver.switch_to.window(win1) print(driver.current_url) time.sleep(2) win2 = driver.window_handles[1] driver.switch_to.window(win2) print(driver.current_url) time.sleep(2) win3 = driver.window_handles[2] driver.switch_to.window(win3) print(driver.current_url) time.sleep(2) win4 = driver.window_handles[3] driver.switch_to.window(win4) print(driver.current_url)
输出结果如图,句柄的第一个元素表示我们第一次打开的主网页界面,
然后我们依次打开了知乎、拉钩、简书,但是句柄列表第二三四个元素依次表示的是简书、拉钩、知乎。
可以认为其从第二个元素往后是与我们代码写入的顺序是相反的。
到此这篇关于python网络爬虫selenium打开多窗口与切换页面的实现的文章就介绍到这了,更多相关python selenium多窗口与切换页面内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!