答案:Python中通过try-except结构处理网络请求异常,结合重试与日志提升程序稳定性。首先捕获ConnectionError、Timeout、HTTPError等具体异常,再由RequestException兜底;使用tenacity实现重试机制应对临时故障;配合logging记录错误信息,既保障用户体验又便于排查问题。

在进行网络请求时,由于网络环境不稳定、服务器异常或请求参数错误等原因,程序很容易出现异常。Python 的异常处理机制可以帮助我们优雅地应对这些问题,避免程序因一次失败的请求而崩溃。合理使用 try-except 结构,能提升程序的健壮性和用户体验。
常见网络请求异常类型
使用 requests 库发起网络请求时,可能会遇到以下几种典型异常:
- requests.exceptions.ConnectionError:网络连接失败,如主机不可达、DNS 解析失败等。
- requests.exceptions.Timeout:请求超时,服务器未在指定时间内响应。
-
requests.exceptions.HTTPError:HTTP 状态码表示错误(如 404、500),可通过
response.raise_for_status()触发。 - requests.exceptions.RequestException:所有 requests 异常的基类,可用于兜底捕获。
基本异常处理结构
下面是一个典型的带异常处理的网络请求示例:
import requests from requests.exceptions import ConnectionError, Timeout, HTTPError, RequestExceptionurl = "https://www.php.cn/link/4d2fe2e8601f7a8018594d98f28706f2"
立即学习“Python免费学习笔记(深入)”;
try: response = requests.get(url, timeout=5) response.raise_for_status() # 检查 HTTP 状态码 print("请求成功:", response.json()) except ConnectionError: print("网络连接失败,请检查网络或目标地址是否可达。") except Timeout: print("请求超时,请尝试增加超时时间或重试。") except HTTPError as e: print(f"HTTP 错误: {e}") except RequestException as e: print(f"请求发生未知错误: {e}")
结合重试机制提升稳定性
对于临时性故障(如短暂超时或服务抖动),可以结合异常处理与重试逻辑提高成功率。使用 tenacity 或手动实现简单重试:
Orz企业网站管理系统整合了企业网站所需要的大部分功能,并在其基础上做了双语美化。压缩包内有必须的图片psd源文件,方便大家修改。 Orz企业网站管理系统功能: 1.动态首页 2.中英文双语同后台管理 3.产品具有询价功能 4.留言板功能 5.动态营销网络 6.打印功能 7.双击自动滚动 Orz企业网站管理系统安装 1、请将官方程序包解压后上传至您的虚拟主机即可正常使用; 2、后台管理面板登录:
from tenacity import retry, stop_after_attempt, wait_fixed@retry(stop=stop_after_attempt(3), wait=wait_fixed(2)) def fetch_data(): try: response = requests.get("https://www.php.cn/link/46b315dd44d174daf5617e22b3ac94ca", timeout=5) response.raise_for_status() return response.json() except ConnectionError: print("连接失败,准备重试...") raise # 触发重试 except Timeout: print("请求超时,准备重试...") raise
通过装饰器设置最多重试 3 次,每次间隔 2 秒,仅对需要重试的异常主动抛出,可有效应对瞬时故障。
日志记录与用户提示
在生产环境中,除了捕获异常,还应记录详细信息以便排查问题。结合 logging 模块可实现:
import logginglogging.basicConfig(level=logging.INFO) logger = logging.getLogger(name)
try: response = requests.get("https://www.php.cn/link/b05edd78c294dcf6d960190bf5bde635", timeout=3) response.raise_for_status() except RequestException as e: logger.error(f"请求失败: {e}, URL: {url}") print("数据加载失败,请稍后重试。")
这样既能保留调试信息,又不会将技术细节暴露给终端用户。
基本上就这些。掌握异常分类、合理分层捕获、结合重试和日志,能让网络请求更可靠。不复杂但容易忽略。









