利用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

 

转载于:https://www.cnblogs.com/helenMemery/p/6543030.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值