如何通过 Python 脚本在 Google Cloud Storage 上上传字节图像

问题描述

我想通过 python 脚本将图像上传到 Google Cloud Storage.这是我的代码:

I want to upload an image on Google Cloud Storage from a python script. This is my code:

from oauth2client.service_account import ServiceAccountCredentials
from googleapiclient import discovery

scopes = ['https://www.googleapis.com/auth/devstorage.full_control']
credentials = ServiceAccountCredentials.from_json_keyfile_name('serviceAccount.json', scop
es)
service = discovery.build('storage','v1',credentials = credentials)

body = {'name':'my_image.jpg'}

req = service.objects().insert(
   bucket='my_bucket', body=body,
   media_body=googleapiclient.http.MediaIoBaseUpload(
      gcs_image, 'application/octet-stream'))

resp = req.execute()

如果 gcs_image = open('img.jpg', 'r') 代码可以正常工作并将我的图像正确保存在 Cloud Storage 上.如何直接上传字节图像?(例如来自 OpenCV/Numpy 数组:gcs_image = cv2.imread('img.jpg'))

if gcs_image = open('img.jpg', 'r') the code works and correctly save my image on Cloud Storage. How can I directly upload a bytes image? (for example from an OpenCV/Numpy array: gcs_image = cv2.imread('img.jpg'))


解决方案

就我而言,我想将 PDF 文档从字节上传到云存储.

In my case, I wanted to upload a PDF document to Cloud Storage from bytes.

当我尝试以下操作时,它创建了一个包含我的字节字符串的文本文件.

When I tried the below, it created a text file with my byte string in it.

blob.upload_from_string(bytedata)

为了使用字节字符串创建一个实际的 PDF 文件,我必须这样做:

In order to create an actual PDF file using the byte string I had to do:

blob.upload_from_string(bytedata, content_type='application/pdf')

我的字节数据是b64encoded,所以我也先b64decode.

My byte data was b64encoded, so I also had b64decode it first.

相关文章