美文网首页
Selenium 浏览器查看信息技巧、截屏、切换窗口

Selenium 浏览器查看信息技巧、截屏、切换窗口

作者: 自如_ | 来源:发表于2019-06-19 09:12 被阅读0次

    WebDriver 对象的一些方法

    3.6 获取当前窗口 title

    driver.title  
    

    比如打开百度,然后打印他的标题。

    from selenium import webdriver
    
    import time
    
    driver = webdriver.Chrome('E:\ChromDriver\chromedriver.exe')
    
    driver.implicitly_wait(10)
    
    driver.get('https://www.baidu.com/')
    
    print(driver.title)
    
    driver.quit()
    

    运行截图:

    image.png

    比如我百度搜索“宋曲”,他的标题也会跟着变。

    image.png

    对应的代码:

    from selenium import webdriver
    import time
    
    driver = webdriver.Chrome('E:\ChromDriver\chromedriver.exe')
    
    driver.implicitly_wait(10)
    
    driver.get('https://www.baidu.com/')
    #找到输入框,输入宋曲
    driver.find_element_by_id("kw").send_keys('宋曲')
    #点击搜索
    driver.find_element_by_id('su').click()
    
    time.sleep(1)
    
    print(driver.title)
    
    driver.quit()
    

    运行截图:


    image.png

    大家注意,我这里为什么加 sleep(1) 因为如果我们的代码执行的很快,窗口还没跳转过来他就打印了窗口的标题,实际上他在打印标题的时候如果没有加 sleep(1) 他打印标题的时候还是百度的页面,有的时候我们打开的不是百度的页面,我们打开某个公司的官网,他的网络服务器可能做的不是那么好,速度时快时慢(比如1~10秒),那我们这里要怎么硬性的等待10秒吗?这种方法太浪费时间,比如他大部分时间3秒内就响应了,那设置10秒是不是多余,我们可以用这种方法,我们打开一个窗口之后去查找里面一个元素,我们判断能不能找到这个元素,去确定这个窗口被打开了,我们搜索宋曲的时候里面会有一个结果。

    image.png

    id='1'webelement,我们只要判断这个元素存不存在就判断页面已经加载成功了。

    代码是:

    from selenium import webdriver
    
    driver = webdriver.Chrome('E:\ChromDriver\chromedriver.exe')
    
    driver.implicitly_wait(10)
    
    driver.get('https://www.baidu.com/')
    
    driver.find_element_by_id("kw").send_keys('宋曲\n')
    
    driver.find_element_by_id('1')
    
    print(driver.title)
    
    driver.quit()
    

    这里就不用 sleep(1) 啦。是不是很完美!!!

    3.6.1 获取当前窗口地址栏 url

    driver.current_url
    

    打开百度打印它的标题URL,输入搜索“宋曲”打印当前的URL和标题

    from selenium import webdriver
    
    driver = webdriver.Chrome('E:\ChromDriver\chromedriver.exe')
    driver.implicitly_wait(10)
    
    driver.get('https://www.baidu.com/')
    #打印标题及url
    print(driver.title)
    print(driver.current_url)
    
    driver.find_element_by_id("kw").send_keys('宋曲\n')
    driver.find_element_by_id('1')
    #打印标题及url
    print(driver.title)
    print(driver.current_url)
    
    driver.quit()
    
    

    输出结果是:


    image.png

    这个地址我们可以拿他做一个校验,比如你点击链接之后看URL是不是你点链接的地址,方法是不是很简单,接下来说一下截屏

    • 截屏
    driver.get_screenshot_as_file(img_path)
    

    我们用代码试一下:

    from selenium import webdriver
    import time
    
    driver = webdriver.Chrome('E:\ChromDriver\chromedriver.exe')
    driver.implicitly_wait(10)
    
    #打开百度,搜索宋曲
    driver.get('https://www.baidu.com/')
    driver.find_element_by_id("kw").send_keys('宋曲')
    
    driver.find_element_by_id('su').click()
    driver.find_element_by_id('1')
    
    #截图
    driver.get_screenshot_as_file('shot.png')
    
    input('press any key to quit...')
    driver.quit()
    

    它截出来的效果是这样的。


    shot.png

    注意截图保存的路径我们可以自己设置比如driver.get_screenshot_as_file('d:\shot.png')就会存到D盘里面,如果我们没有设它默认的就是当前工作目录,我们可以点击

    image.png

    然后点击:


    image.png

    然后会看到它默认的工作的目录就是当前的项目文件夹。


    image.png

    有的时候我们不想截整个图片,比如我们要截某一个元素,比如截百度一下的log,需要找到它的 id ,先获取到这个元素,然后在调用 screenshot 方法。对应的代码是:

    from selenium import webdriver
    import time
    
    driver = webdriver.Chrome('E:\ChromDriver\chromdriver2.43\chromedriver.exe')
    driver.implicitly_wait(10)
    
    driver.get('https://www.baidu.com/')
    ele = driver.find_element_by_id('lg')
    ele.screenshot('baidulog.png')
    driver.quit()
    
    

    截到的效果是:


    baidulog.png

    判断有没有截到可以通过TrueFlast来判断。

    3.6.2 切换窗口

    比如我百度宋曲,点击第一个搜索结果,他会跳到一个新的窗口,我们前面用Webdriver来操控窗口,那新打开的窗口可不可以用Webdriver来操控呢,看下面的代码点击新窗口之后,点击“帮助”按钮。

    image.png

    代码如下:

    from selenium import webdriver
    import time
    
    driver = webdriver.Chrome('E:\ChromDriver\chromedriver.exe')
    driver.implicitly_wait(10)
    
    driver.get('https://www.baidu.com/')
    print(driver.title)
    
    driver.find_element_by_id('kw').send_keys('宋曲\n')
    
    #点击第一条搜索结果,进入百度百科
    ele=driver.find_element_by_xpath('//div[@id="1"]/h3/a').click()
    #点击帮助按钮
    ele2 = driver.find_element_by_xpath('//button[@id="searchLemma"]/following-sibling::a').click()
    
    title=driver.title
    
    print(title)
    
    driver.quit()
    
    

    它会报错:


    image.png

    会报错找不到元素,这里的原因是:driver 对象他在前面的窗口当中去控制浏览器点击之类的,他对浏览器的控制权只停留在第一个上面,他只控制前面自己打开的窗口,如果点了一个超链接打开了一个新的窗口 webdriver 对新的窗口是没有控制权的,他不知道的新打开的连接 HTML 里面有什么内容,没办法控制新打开的窗口,怎么样才能把控制权从前面的窗口跳到新打开的窗口呢,我们可以通过切换窗口来解决。

    • 切换窗口:
    driver.switch_to.window(handle)
    

    handle 代表窗口的句柄,本质是一个字符串。这个方法通过唯一一个参数,就可以切入新的窗口了。

    • 如何获取 handle ?

    通过:

    driver.window_handles
    

    方法获取当前浏览器所有窗口的 handle,通过循环切换窗口判断标题的方法来确定当前窗口是否为目标窗口,保留当前窗 handle:

    driver.current_window_handle
    

    我们在之前的代码上加上 driver.window_handles 方法,看看打印的结果是什么。

    from selenium import webdriver
    import time
    
    driver = webdriver.Chrome('E:\ChromDriver\chromedriver.exe')
    driver.implicitly_wait(10)
    
    driver.get('https://www.baidu.com/')
    print(driver.title)
    
    driver.find_element_by_id('kw').send_keys('宋曲\n')
    
    #点击第一条搜索结果,进入百度百科
    ele=driver.find_element_by_xpath('//div[@id="1"]/h3/a').click()
    # 显示 标题栏 文本,可以发现还是在当前网页
    print(driver.title)
    print(driver.window_handles)
    
    driver.quit()
    

    运行结果:


    image.png

    可以看到 driver.window_handles返回的是一个列表对象,这个列表里面有 2 个值分别对应了 2个窗口,如果我们打开的窗口很多,就会有好多字符串,我们不可能猜那个字符串对应那个窗口,那我们怎么知道那个是对应的呢,可以通过我们上面说的 titleURL都可以,比如我们这里用 title ,我们获取到 handles 可以去循环遍历一下,拿到 handle 就切进去,然后就判断宋曲的这个字符串是否被标题包含,如果包含就停止循环,我们可以看到其实我们停止循环他就切进来了,切进来之后我们打印下 title 看有没有切入。

    from selenium import webdriver
    
    driver = webdriver.Chrome('E:\ChromDriver\chromedriver.exe')
    driver.implicitly_wait(10)
    
    driver.get('https://www.baidu.com/')
    
    driver.find_element_by_id('kw').send_keys('宋曲\n')
    
    #点击第一条搜索结果,进入百度百科
    ele=driver.find_element_by_xpath('//div[@id="1"]/h3/a').click()
    # 显示 标题栏 文本,可以发现还是在当前网页
    print(driver.title)
    print(driver.window_handles)
    
    for handle in driver.window_handles:
    #切换到新窗口
        driver.switch_to_window(handle)
    #检查是否是我们要进入的window
        if '宋曲_百度百科' in driver.title:
            break
    #点击帮助按钮
    ele2 = driver.find_element_by_xpath('//button[@id="searchLemma"]/following-sibling::a').click()
    
    print(driver.title)
    

    看运行截图:


    image.png

    这样就切入运行起来了, title 就变了,如果我们想判断当前的 handle 到底是那个,我们可以在 for 循环里面打印一下。

    for handle in driver.window_handles:
        driver.switch_to_window(handle)
        if '宋曲_百度百科' in driver.title:
            print(handle)
            break
    

    运行截图:


    image.png

    这样就可以啦!大家注意切入到新窗口的时候就失去了对原来窗口的控制权,如果想点击原来窗口的元素是没有效果的,想回到最初的窗口可以把当前的 handle 字符串保存下来,字符串相当于窗口的唯一 id,拿到 id 才能切换到窗口,保存主窗口 handle

    driver.current_window_handle
    

    代码:

    from selenium import webdriver
    import time
    
    driver = webdriver.Chrome('E:\ChromDriver\chromedriver.exe')
    driver.implicitly_wait(10)
    
    driver.get('https://www.baidu.com/')
    
    driver.find_element_by_id('kw').send_keys('宋曲\n')
    
    #点击第一条搜索结果,进入百度百科
    ele=driver.find_element_by_xpath('//div[@id="1"]/h3/a').click()
    # 显示 标题栏 文本,可以发现还是在当前网页
    print(driver.title)
    
    #保存主窗口handle
    mainWindow = driver.current_window_handle
    
    # 显示 标题栏 文本,可以发现还是在当前网页
    print(driver.window_handles)
    
    for handle in driver.window_handles:
    #切换至新窗口
        driver.switch_to_window(handle)
    #检查是否是我们要进入的window
        if '宋曲_百度百科' in driver.title:
            print(handle)
            break
    #点击帮助按钮
    ele2 = driver.find_element_by_xpath('//button[@id="searchLemma"]/following-sibling::a').click()
    
    #切换到主窗口
    
    driver.switch_to_window(mainWindow)
    
    driver.find_element_by_id('kw').send_keys('111')
    
    time.sleep(3)
    
    driver.quit()
    

    我们打开多个窗口怎么关闭呢? 用 close() 方法:

    driver.close()  #用于关闭当前窗口
    

    代码:

    from selenium import webdriver
    import time
    
    driver = webdriver.Chrome('E:\ChromDriver\chromedriver.exe')
    driver.implicitly_wait(10)
    
    driver.get('https://www.baidu.com/')
    
    driver.find_element_by_id('kw').send_keys('宋曲\n')
    
    #点击第一条搜索结果,进入百度百科
    ele=driver.find_element_by_xpath('//div[@id="1"]/h3/a').click()
    
    # 显示 标题栏 文本,可以发现还是在当前网页
    print(driver.title)
    
    #保存主窗口handle
    mainWindow = driver.current_window_handle
    
    # 显示 标题栏 文本,可以发现还是在当前网页
    print(driver.window_handles)
    
    for handle in driver.window_handles:
    #切换到新窗口
        driver.switch_to.window(handle)
    #检查是否是我们要进入的window
        if '宋曲_百度百科' in driver.title:
            print(handle)
            break
    #点击帮助按钮
    ele2 = driver.find_element_by_xpath('//button[@id="searchLemma"]/following-sibling::a').click()
    
    #关闭窗口
    driver.close()
    time.sleep(5)
    
    #切换到主窗口
    driver.switch_to.window(mainWindow)
    
    driver.find_element_by_id('kw').send_keys('111')
    
    input('press any key to quit...')
    driver.quit()
    

    可以自己运行看下效果。

    相关文章

      网友评论

          本文标题:Selenium 浏览器查看信息技巧、截屏、切换窗口

          本文链接:https://www.haomeiwen.com/subject/wnvfqctx.html