zoukankan      html  css  js  c++  java
  • 利用page_source抓取网页中的URL,进行链接测试

    selenium的page_source方法可以获取到页面源码,下面就把它应用到链接测试中。

    # coding:utf-8
    __author__ = 'helen'
    import re,requests
    from selenium import webdriver
    
    # 爬取网页资源,并用正则表达式匹配出URL
    def get_urlList(target_page):
        driver = webdriver.Firefox()
        driver.get(target_page)
        # 获取网页资源
        page = driver.page_source
        # 用正则表达式匹配URL集
        url_context = re.findall('href="(.*?)"',page,re.S)
        url_list = []
        for url in url_context:
            # 因为url_context中匹配的内容有些不是URL,所以加个if来过滤一下
            if 'http'in url:
                url_list.append(url)
        # 因为网页中的URL基本是正确的,下面我们可以加入一个不存在的URL,检查异常URL的输出
        url_list.append('http://www.cnblogs.com/helenMemery/p/35.html')
        return url_list
    
    # 通过request.get检查URL的返回编码状态,以确认URL返回正常
    def test_url(url_list):
        try:
            for url in url_list:
                r = requests.get(url=url)
                if r.status_code !=200:
                    print url
        except requests.HTTPError,e:
            e.strerror
    if __name__ == '__main__':
        target_page = 'http://www.cnblogs.com/helenMemery/'
        url_list = get_urlList(target_page)
        test_url(url_list)

    在此感谢悠总的分享:http://www.cnblogs.com/yoyoketang/p/6512604.html

  • 相关阅读:
    深度学习分类网络的发展历史
    杨辉三角
    【了解】贝塞尔曲线
    win10桌面点击事件蓝色边框处理
    try{}catch的隐藏(如何优雅的实现异常块)
    switch的一些思考(seitch与ifelse的区别)
    好看的控制台日志线
    Serializable和Externalizabl的异同
    java排序方式对比
    如何初始化Map,java
  • 原文地址:https://www.cnblogs.com/helenMemery/p/6543030.html
Copyright © 2011-2022 走看看