全部產品
Search
文件中心

Object Storage Service:Python下載進度條

更新時間:Oct 25, 2024

進度條用於指示上傳或下載的進度。

注意事項

  • 本文以華東1(杭州)外網Endpoint為例。如果您希望通過與OSS同地區的其他阿里雲產品訪問OSS,請使用內網Endpoint。關於OSS支援的Region與Endpoint的對應關係,請參見OSS訪問網域名稱、資料中心、開放連接埠

  • 本文以從環境變數讀取存取憑證為例。如何配置訪問憑證,請參見配置訪問憑證

  • 本文以OSS網域名稱建立OSSClient為例。如果您希望通過自訂網域名、STS等方式建立OSSClient,請參見初始化

範例程式碼

下面的代碼以bucket.get_object_to_file方法為例,介紹如何使用進度條。

# -*- coding: utf-8 -*-
from __future__ import print_function
import os
import sys
import oss2
from oss2.credentials import EnvironmentVariableCredentialsProvider
# 從環境變數中擷取訪問憑證。運行本程式碼範例之前,請確保已設定環境變數OSS_ACCESS_KEY_ID和OSS_ACCESS_KEY_SECRET。
auth = oss2.ProviderAuthV4(EnvironmentVariableCredentialsProvider())

# 填寫Bucket所在地區對應的Endpoint。以華東1(杭州)為例,Endpoint填寫為https://oss-cn-hangzhou.aliyuncs.com。
endpoint = "https://oss-cn-hangzhou.aliyuncs.com"

# 填寫Endpoint對應的Region資訊,例如cn-hangzhou。注意,v4簽名下,必須填寫該參數
region = "cn-hangzhou"

# yourBucketName填寫儲存空間名稱。
bucket = oss2.Bucket(auth, endpoint, "yourBucketName", region=region)

# 當HTTP回應標頭部沒有Content-Length時,total_bytes的值為None。
# consumed_bytes表示已下載檔案的大小,單位為位元組。
# total_bytes表示下載檔案的總大小,單位為位元組。
def percentage(consumed_bytes, total_bytes):
    if total_bytes:
        rate = int(100 * (float(consumed_bytes) / float(total_bytes)))
        # rate表示下載進度。
        print('\r{0}% '.format(rate), end='')

        sys.stdout.flush()

# progress_callback是選擇性參數,用於實現進度條功能。
bucket.get_object_to_file('yourObjectName', 'yourLocalFile', progress_callback=percentage)

相關文檔

關於下載檔案的進度條使用方法的完整範例程式碼,請參見GitHub樣本