跳转到主要内容

下载

简介

页面下载的每个附件都会触发 page.on("download") 事件。所有这些附件都会下载到一个临时文件夹中。你可以使用事件中的 Download 对象获取下载的 URL、文件名和有效载荷流。

你可以在 browser_type.launch() 中使用 downloads_path 选项指定下载文件的存储路径。

注意

下载的文件会在产生它们的浏览器上下文关闭时被删除。

这是处理文件下载的最简单方法

# Start waiting for the download
with page.expect_download() as download_info:
# Perform the action that initiates download
page.get_by_text("Download file").click()
download = download_info.value

# Wait for the download process to complete and save the downloaded file somewhere
download.save_as("/path/to/save/at/" + download.suggested_filename)

变体

如果你不知道是什么启动了下载,你仍然可以处理这个事件

page.on("download", lambda download: print(download.path()))

请注意,处理事件会分叉控制流,使脚本更难理解。你的主控制流可能没有等待此操作解析,因此你的场景可能在下载文件时结束。

注意

有关上传文件,请参阅上传文件部分。