91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python如何實現上傳文件到OSS

發布時間:2020-07-28 12:07:06 來源:億速云 閱讀:558 作者:小豬 欄目:開發技術

小編這次要給大家分享的是python如何實現上傳文件到OSS,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

基礎環境

# +++++ 阿里云OSS開發指南里都有詳細的步驟,在這里整理了一下自己需要的東西
# 確定開發環境,centOS默認安裝了python2.7
# python -V
# 安裝python開發包
# yum install -y python-devel
# 安裝OSS的sdk
# yum install -y python-pip
# pip2.7 install oss2
# 驗證oss2是否安裝正確
'''
>>> import oss2
>>> oss2.__version__
'2.6.0'
'''
# 驗證OSS擴展庫crcmod是否安裝
'''
在python環境中,輸入一下內容,如果有錯誤信息,則說明擴展庫安裝不成功,默認安裝oss2的時候會安裝擴展庫
>>> import crcmod._crcfunext
如果出現安裝不成功,則按一下步驟安裝:
1、執行以下命令卸載crcmod
# pip uninstall crcmod
2、安裝python-devel
3、執行以下命令重新安裝crcmod
# pip install crcmod
'''

小文件上傳

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import oss2

# 阿里云主賬號AccessKey擁有所有API的訪問權限,風險很高。強烈建議您創建并使用RAM賬號進行API訪問或日常運維,請登錄 https://ram.console.aliyun.com 創建RAM賬號。
auth = oss2.Auth('<yourAccessKeyId>', '<yourAccessKeySecret>')
# Endpoint以杭州為例,其它Region請按實際情況填寫。
bucket = oss2.Bucket(auth, 'http://oss-cn-hangzhou.aliyuncs.com', '<yourBucketName>')

# 必須以二進制的方式打開文件,因為需要知道文件包含的字節數。
with open('<yourLocalFile>', 'rb') as fileobj:
  # Seek方法用于指定從第1000個字節位置開始讀寫。上傳時會從您指定的第1000個字節位置開始上傳,直到文件結束。
  fileobj.seek(1000, os.SEEK_SET)
  # Tell方法用于返回當前位置。
  current = fileobj.tell()
  bucket.put_object('<yourObjectName>', fileobj)


分片上傳

# -*- coding: utf-8 -*-import os
from oss2 import SizedFileAdapter, determine_part_size
from oss2.models import PartInfo
import oss2

# 阿里云主賬號AccessKey擁有所有API的訪問權限,風險很高。強烈建議您創建并使用RAM賬號進行API訪問或日常運維,請登錄 https://ram.console.aliyun.com 創建RAM賬號。
auth = oss2.Auth('<yourAccessKeyId>', '<yourAccessKeySecret>')
# Endpoint以杭州為例,其它Region請按實際情況填寫。
bucket = oss2.Bucket(auth, 'http://oss-cn-hangzhou.aliyuncs.com', '<yourBucketName>')

key = '<yourObjectName>'
filename = '<yourLocalFile>'

total_size = os.path.getsize(filename)
# determine_part_size方法用來確定分片大小。
part_size = determine_part_size(total_size, preferred_size=100 * 1024)

# 初始化分片。
upload_id = bucket.init_multipart_upload(key).upload_id
parts = []

# 逐個上傳分片。
with open(filename, 'rb') as fileobj:
  part_number = 1
  offset = 0
  while offset < total_size:
    num_to_upload = min(part_size, total_size - offset)
        # SizedFileAdapter(fileobj, size)方法會生成一個新的文件對象,重新計算起始追加位置。
    result = bucket.upload_part(key, upload_id, part_number,
                  SizedFileAdapter(fileobj, num_to_upload))
    parts.append(PartInfo(part_number, result.etag))

    offset += num_to_upload
    part_number += 1

# 完成分片上傳。
bucket.complete_multipart_upload(key, upload_id, parts)

# 驗證分片上傳。
with open(filename, 'rb') as fileobj:
  assert bucket.get_object(key).read() == fileobj.read()

看完這篇關于python如何實現上傳文件到OSS的文章,如果覺得文章內容寫得不錯的話,可以把它分享出去給更多人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

揭西县| 涟源市| 阿坝| 吉林市| 巴彦淖尔市| 石家庄市| 略阳县| 灵山县| 岑巩县| 道孚县| 读书| 嘉兴市| 盐津县| 余庆县| 滦平县| 乌兰察布市| 云安县| 武冈市| 安达市| 定日县| 镇坪县| 河津市| 广德县| 固始县| 绥德县| 安西县| 车致| 沧源| 乌苏市| 绥滨县| 安义县| 昌乐县| 香格里拉县| 汉沽区| 安康市| 廉江市| 莲花县| 阿鲁科尔沁旗| 肇源县| 南郑县| 偃师市|