如何使用try-except语句处理Python中的异常

本文涉及的产品
云原生数据库 PolarDB PostgreSQL 版,企业版 4核16GB
推荐场景:
HTAP混合负载
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 如何使用try-except语句处理Python中的异常

在python爬虫行业里面,异常处理能力已经成为了一项非常重要的技能。随着软件规模的不断扩大和复杂性的增加,异常处理能力已经成为了评判一个示波器水平的重要指标。 ,学会使用try-except语句来捕获和处理Python异常,对于我们做爬虫的来说是非常有必要的。
try- except语句是一种常用的异常处理机制。由于网络环境的不稳定性和网站的变化,爬虫程序经常会遇到各种问题异常情况,例如网络连接超时、页面解析错误、请求被拒绝等。为了保证爬虫的稳定性和可靠性,我们可以使用try- except语句来捕获和处理这些异常。
比如在最近的开发日志中,我遇到了一个令人头疼的问题。那就是访问12306购票的问题。我需要访问一个网站来获取火车票的信息,但是遇到访问异常的情况,比如超时、HTTP错误、代理错误等等。这让我非常困惑,因为我希望我的代码能够优雅地处理这些异常,而不是让程序崩溃。
为了解决这个问题,我决定使用try-except语句来捕获和处理这些异常情况。通过合理地设置代理信息,为了并使用try- except语句来处理可能出现的异常。
try-except语句的基本结构如下:

    # 可能会出现异常的代码块
    ...
except ExceptionType:
    # 处理异常的代码块
    ...

下面是一个示例代码,演示了如何使用try- except语句来捕获和处理Python异常:
```import requests

设置代理信息

proxyHost = "www.16yun.cn"
proxyPort = "5445"
proxyUser = "16QMSOML"
proxyPass = "280651"

设置访问链接

url = "https://www.12306.cn/"

try:

# 使用代理访问12306网站
proxies = {
    "http": f"http://{proxyUser}:{proxyPass}@{proxyHost}:{proxyPort}",
    "https": f"https://{proxyUser}:{proxyPass}@{proxyHost}:{proxyPort}"
}
response = requests.get(url, proxies=proxies, timeout=5)
response.raise_for_status()  # 检查响应状态码
print("恭喜你,成功访问到12306网站!")

except requests.exceptions.Timeout:
print("哎呀,访问超时了,请稍后再试。")
except requests.exceptions.HTTPError:
print("糟糕,遇到了HTTP错误,请检查你的网络连接。")
except requests.exceptions.ProxyError:
print("天啊,代理出了问题,请检查你的代理设置。")
except requests.exceptions.RequestException:
print("糟糕透顶,发生了其他异常,请检查你的网络连接。")

```
在实际开发中,我们还可以根据具体的需求,进一步完善异常处理逻辑。例如,可以设置重试机制,当请求失败时自动重新尝试;或者记录异常信息到日志文件,以便后续分析和排查问题。
总结起来,使用Python爬虫访问12306购票网站时,try-except语句是我们一个重要的异常处理机制。通过合理地使用try- except语句,可以捕获和处理各种可能的异常情况,提高爬虫程序的稳定性和可靠性。同时,我们还可以根据具体的异常类型来执行不同的处理逻辑,以应对不同的异常情况。

相关文章
|
1月前
|
Unix API Python
【Python】已完美解决:(Python3.8异常)AttributeError: module ‘time‘ has no attribute ‘clock‘
【Python】已完美解决:(Python3.8异常)AttributeError: module ‘time‘ has no attribute ‘clock‘
41 0
|
2月前
|
Python
Python基础教程(第3版)中文版 第8章 异常(笔记)
Python基础教程(第3版)中文版 第8章 异常(笔记)
|
3月前
|
索引 Python
Python中的异常处理与自定义异常
Python中的异常处理与自定义异常
36 0
|
1月前
|
数据采集 存储 Java
如何让Python爬虫在遇到异常时继续运行
构建健壮Python爬虫涉及异常处理、代理IP和多线程。通过try/except捕获异常,保证程序在遇到问题时能继续运行。使用代理IP(如亿牛云)防止被目标网站封锁,多线程提升抓取效率。示例代码展示了如何配置代理,设置User-Agent,以及使用SQLite存储数据。通过`fetch_url`函数和`ThreadPoolExecutor`实现抓取与重试机制。
如何让Python爬虫在遇到异常时继续运行
|
23天前
|
机器学习/深度学习 运维 监控
使用Python实现深度学习模型:智能安防监控与异常检测
【7月更文挑战第26天】 使用Python实现深度学习模型:智能安防监控与异常检测
37 6
|
1月前
|
机器学习/深度学习 数据采集 算法
Python实现Prophet时间序列数据建模与异常值检测(Prophet算法)项目实战
Python实现Prophet时间序列数据建模与异常值检测(Prophet算法)项目实战
|
2月前
|
编译器 索引 Python
Python常见异常类型说明及触发代码示例
开发过程中需要根据具体情况选择处理异常,并使用try-except语句来捕获并处理异常,从而保证程序的健壮性和稳定性。在Python中,异常是程序执行期间发生的错误或意外情况。当解释器遇到异常时,会停止程序的正常执行,并在控制台输出异常的相关信息。Python中有许多不同的异常类型,每个异常类型表示不同的错误或意外情况。OSError:操作系统产生的异常(例如打开一个不存在的文件)。AttributeError:尝试访问一个对象没有的属性。UnicodeError:Unicode相关的异常。
117 5
|
2月前
|
Python
python执行elasticsearch异常【已解决】
python执行elasticsearch异常【已解决】
26 2
|
1月前
|
机器学习/深度学习 运维 算法
Python基于局部离群因子LOF算法(LocalOutlierFactor)实现信用卡数据异常值检测项目实战
Python基于局部离群因子LOF算法(LocalOutlierFactor)实现信用卡数据异常值检测项目实战