乐闻世界logo
搜索文章和话题

How to know if urllib.urlretrieve succeeds?

5 个月前提问
5 个月前修改
浏览次数23

1个答案

1

当使用 urllib.urlretrieve 方法从网络上下载文件时,判断其是否成功主要依赖于该方法的返回值以及是否有异常抛出。

1. 检查返回值

urllib.urlretrieve 会返回一个元组,其中包含两个元素:

  • 第一个元素是本地文件的路径(即下载文件保存的位置)。
  • 第二个元素是一个由 HTTP 头部组成的对象。

例如:

python
import urllib.request try: local_filename, headers = urllib.request.urlretrieve('http://www.example.com/somefile.zip', 'localfile.zip') print("下载成功!") print("本地文件路径:", local_filename) print("HTTP头部信息:", headers) except Exception as e: print("下载失败:", e)

2. 检查异常

如果在下载过程中遇到问题(如网络问题、URL 问题等),urllib.urlretrieve 通常会抛出异常,如 URLErrorHTTPError 等。因此,使用 try-except 块来捕获这些异常是判断下载是否成功的关键。

在上面的代码示例中,如果下载成功,会打印下载的文件路径和HTTP头信息;如果失败,则会捕获异常并打印错误信息。

3. 分析HTTP头部信息

通过检查返回的 HTTP 头部信息,可以进一步确认文件是否完整或者是否为预期的文件类型。例如,可以检查头部中的 Content-Length,与实际下载的文件大小进行对比,确保文件未被截断:

python
import os file_size = os.path.getsize(local_filename) header_size = headers.get("Content-Length") if str(file_size) == header_size: print("文件完整性验证通过。") else: print("文件可能已损坏。")

通过以上步骤,你可以比较全面地判断 urllib.urlretrieve 的下载操作是否成功。

2024年8月5日 02:19 回复

你的答案