如何将Google客户端视觉库响应转换为Json

问题描述 投票:0回答:2

我正在尝试将 Google Cloud Vision API 客户端库的响应转换为 json 格式。但是我收到以下错误:

属性错误:'google.protobuf.pyext._message.RepeatedCompositeCo' 对象没有属性“DESCRIPTOR

资源

from flask_restful import Resource
from flask import request
from flask import json
from util.GoogleVision import GoogleVision
from util.Convert import Convert

import base64
import requests

import os


class Vision(Resource):

    def post(self):

        googleVision = GoogleVision()

        req = request.get_json()

        url = req['url']

        result = googleVision.detectLabels(url)

        return result

GoogleVision.py

import os

from google.cloud import vision
from google.cloud.vision import types
from google.protobuf.json_format import MessageToJson

class GoogleVision():

    def detectLabels(self, uri):

        client = vision.ImageAnnotatorClient()
        image = types.Image()
        image.source.image_uri = uri

        response = client.label_detection(image=image)
        labels = response.label_annotations

        res = MessageToJson(labels)

        return res

标签变量的类型为

<class'google.protobuf.pyext._message.RepeatedCompositeContainer'>

如您所见,我在标签响应上使用消息到 json 函数。但我收到了上述错误。

有没有办法将结果转换为json格式?

python json google-api protocol-buffers google-cloud-vision
2个回答
8
投票

一种简单的方法是使用 Discovery API。您可以使用 build() 函数创建服务对象。执行请求时,您将获得字典形式的响应。然后您可以使用

json.dumps()
将其转换为 JSON。

Discovery API 示例:

import json
import apiclient.discovery
import base64

class GoogleVision():

    def detectLabels(self, uri):

        # Instantiates a client
        service = apiclient.discovery.build('vision', 'v1')

        # Image file
        file_name=uri

        # Loads the image into memory
        with open(file_name, 'rb') as image:
            image_content = base64.b64encode(image.read())

            # Creates the request
            service_request = service.images().annotate(body={
                'requests': [{
                    'image': {
                        'content': image_content.decode('UTF-8')
                    },
                    'features': [{
                        'type': 'LABEL_DETECTION',
                    }]
                }]
            })

        # Execute the request  
        response = service_request.execute()

        # Convert to Json
        res_json = json.dumps(response)

        return res_json

如果您不想使用 Discovery API,可以先使用

MessageToDict()
函数将响应转换为字典,然后使用
json.dumps()
转换为 JSON。

不使用 Discovery API 的示例

MessageToDict()
:

import json
from google.cloud import vision
from google.cloud.vision import types
from google.protobuf.json_format import MessageToDict

class GoogleVision():

    def detectLabels(self, uri):

        # Instantiates a client
        client = vision.ImageAnnotatorClient()

        # Image file
        file_name=uri

        # Loads the image into memory
        with open(file_name, 'rb') as image:
            image_content = image.read()

        image = types.Image(content=image_content)

        # Performs label detection on the image file
        response = client.label_detection(image=image)       

        #Convert the response to dictionary
        response = MessageToDict(response)

        # Convert to Json
        res_json = json.dumps(response)

        return res_json

0
投票

你可以尝试:

from google.protobuf.json_format import MessageToDict


(Pdb) type(response)
<class 'google.cloud.vision_v1.types.image_annotator.BatchAnnotateFilesResponse'>

print(MessageToDict(response._pb))
{'responses': [{'responses': [...]},...]}
© www.soinside.com 2019 - 2024. All rights reserved.