处理地址异常

本文介绍了一个使用Python进行网页抓取的例子,并展示了如何利用BeautifulSoup解析HTML内容。此外,还详细说明了如何通过合理地设置异常捕获顺序来确保能够正确地区分HTTPError和URLError,从而更精确地定位问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

from urllib.request import urlopen
from urllib.error import HTTPError,URLError
from bs4 import BeautifulSoup
'''
如果想用HTTPError和URLError一起捕获异常,那么需要将HTTPError放在URLError的前面,
因为HTTPError是URLError的一个子类。如果URLError放在前面,出现HTTP异常会先响应URLError,
这样HTTPError就捕获不到错误信息了
'''
def getTitle(url):
    try:
        html = urlopen(url)
    except HTTPError as e:
        print('HTTPError:%s'%e.code)
        return None
    except URLError as e:
        print('URLError:%s'%e.code)
    try:
        bsObj = BeautifulSoup(html,'html.parser')
        title = bsObj.body.h12
        import pdb
        pdb.set_trace()
    except AttributeError as e:
        print('AttributeError:%s'%e.code)
        return None
    print('1')
    return title
title = getTitle("http://www.pythonscraping.com/pages/page1.html")
if title == None:
    print("Title could not be found")
else:
    print(title)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值