如何使用python发送rest API(Google Vision的API)请求?



我想我的问题相对简单和幼稚,但我是使用 REST API 的新手,所以我将不胜感激任何帮助或提示。

我正在尝试使用 urllib(或我不需要安装的另一个 Python 库(发送请求。根据他们的指南,格式为:

POST https://vision.googleapis.com/v1/images:annotate?key=YOUR_API_KEY

JSON 请求格式为:

{
  "requests":[
    {
      "image":{
        "content":"/9j/7QBEUGhvdG9...image contents...eYxxxzj/Coa6Bax//Z"
      },
      "features":[
        {
          "type":"LABEL_DETECTION",
          "maxResults":1
        }
      ]
    }
  ]
}

当我尝试在浏览器的 URL 行中发送以下文本(仅用于测试(时:

https://vision.googleapis.com/v1/images:{
  "requests":[
    {
      "image":{
        "content":"/9j/7QBEUGhvdG9eYxxxzj/Coa6Bax//Z"
      },
      "features":[
        {
          "type":"LABEL_DETECTION",
          "maxResults":1
        }
      ]
    }
  ]
}?key=my_api_key

不幸的是,我收到404错误。

我该怎么办?我应该使用任何库来生成请求吗?还是应该将 JSON 请求放在 URL 中的其他位置?

如果您需要发送带有URL的Request Body,您可以使用CURL .为了测试REST API,有一个名为POSTMAN的著名软件。通过使用此功能,您可以发送请求并接收响应。

卷曲

curl -v -H "Content-Type: application/json" -X POST 
     -d '{"image":{"content":"/9j/7QBEUGhvdG9...image contents...eYxxxzj/Coa6Bax//Z"}, "features":[{"type":"LABEL_DETECTION","maxResults":1}]}' https://vision.googleapis.com/v1/images:annotate?key=YOUR_API_KEY

使用POSTMAN,您可以为它提供这些值并获得结果。

提供网址,

https://vision.googleapis.com/v1/images:annotate?key=YOUR_API_KEY

选择 HTTP 方法作为,

POST

并在raw字段下添加请求正文,然后选择JSON(application/json)

{
  "requests":[
    {
      "image":{
        "content":"/9j/7QBEUGhvdG9...image contents...eYxxxzj/Coa6Bax//Z"
      },
      "features":[
        {
          "type":"LABEL_DETECTION",
          "maxResults":1
        }
      ]
    }
  ]
}

这对我有用:

import base64
import requests
import json
URL = "https://vision.googleapis.com/v1/images:annotate?key=YOUR_TOKEN"
#image to base64, which is a long long text
def encode_image(image_path):
    with open(image_path, "rb") as image_file:
        return base64.b64encode(image_file.read())
#make api call
def image_request(image_path):
    data = {
            "requests":[
                        {
                        "image":{
                            "content":encode_image(image_path)
                                },
                        "features":[
                                    {
                                    "type":"LABEL_DETECTION", #other options: LABEL_DETECTION FACE_DETECTION LOGO_DETECTION CROP_HINTS WEB_DETECTION
                                    "maxResults": 10
                                    }
                                   ]
                        }
                    ]
}
    r = requests.post(URL, json = data)
    return r.text

#arg = path of image
def main(argv):
    api_answer = json.loads(image_request(argv[1]))
    try:
        rows = api_answer['responses'][0]['labelAnnotations']
    except:
        print(file_to_proccess)
        print(api_answer)
    data = []
    for item in rows:
        data.append([item['mid'], item['description'], item['score'], item['topicality']])
    # save somewhere the data list...
if __name__ == "__main__":
    main(sys.argv)

已经过测试并且工作得很好

            import base64
            import requests
            import json
            url = "https://vision.googleapis.com/v1/images:annotate"
            querystring = {"key":".........."}
            headers = {
                    'Content-Type': "application/json",
                    }
            def encode_image(image_path):
                with open(image_path, "rb") as image_file:
                    return base64.b64encode(image_file.read())
            def image_request(image_path):
                payload = '{  "requests":[    {      "image":{        "content":"'+encode_image(image_path).decode('utf-8')+'"      },      "features":[        {          "type":"TEXT_DETECTION" }      ]    }  ]}'
                response = requests.request("POST", url, data=payload, headers=headers, params=querystring)
                return response.text

相关内容

  • 没有找到相关文章

最新更新