gpt4 book ai didi

google-cloud-platform - 收到无效的 JSON 负载。未知名称\"row\"在 'payload' : Cannot find field on google automl api

转载 作者:行者123 更新时间:2023-12-03 23:05:56 25 4
gpt4 key购买 nike

我正在尝试实现 google automl api
https://cloud.google.com/automl-tables/docs/predict
api 文档说我需要按以下格式发布数据

{
"payload": {
"row": {
"values": [value1, value2,...]
}
}
}
但是当我以相同的格式发布数据时,出现以下错误。
{
"error": {
"code": 400,
"message": "Invalid JSON payload received. Unknown name \"row\" at 'payload': Cannot find field.",
"status": "INVALID_ARGUMENT",
"details": [
{
"@type": "type.googleapis.com/google.rpc.BadRequest",
"fieldViolations": [
{
"field": "payload",
"description": "Invalid JSON payload received. Unknown name \"row\" at 'payload': Cannot find field."
}
]
}
]
}
}
这是我的 curl 请求
curl --location --request POST 'https://automl.googleapis.com/v1/projects/project-id/locations/us-central1/models/TBLID:predict' \
--header 'Content-Type: application/json; charset=utf-8;' \
--header 'Accept-Charset: utf-8' \
--header 'Authorization: Bearer token here' \
--data-raw '{
"payload": {
"row": {
"values": [
"",
"4.900000",
""
]
}
}
}'
我不确定是什么导致了这个错误。谁能帮忙解决这个问题谢谢

最佳答案

我有一个带有 AutoML 表的项目,这是一个发送的示例预测请求,它工作正常并且返回结果没有错误:

{
"payload": {
"row": {
"values": [
"2",
"test text",
"test text",
"21",
"0",
"0",
"test text",
"10",
"",
"S"
]
}
}
}
如果您不确定如何提交数据或遇到错误,请在控制台中转到您的项目和 AutoML Tables 模型,然后单击“测试和使用”。然后,按照 getting an online prediction from console 的这些说明进行操作.请注意 JSON 代码 View ,它将为您提供准确的输入并让您测试 JSON 输入。
为了测试,我提交了以下 curl 请求(更改了一些识别字符)
curl -X POST \
-H "Authorization: Bearer "$(gcloud auth application-default print-access-token) \
-H "Content-Type: application/json; charset=utf-8" \
-d @request.json \
https://automl.googleapis.com/v1beta1/projects/this-isnt-a-real-project-id/locations/us-central1/models/TBL123451234512345:predict
我发送请求的同一目录中的 request.json 文件是:
{
"payload": {
"row": {
"values": [
"yes",
"-1",
"primary",
"jul",
"51",
"0",
"yes",
"no",
"88",
"cellular",
"blue-collar",
"unknown",
"10",
"620",
"married"
]
}
}
}
回应是:
{
"payload": [
{
"tables": {
"score": 0.9999906,
"value": "no"
}
},
{
"tables": {
"score": 9.42341e-06,
"value": "yes"
}
}
]
}
我也在下面的 postman 中成功地重复了同样的请求:
curl --location --request POST 'https://automl.googleapis.com/v1beta1/projects/this-isnt-a-real-project-id/locations/us-central1/models/TBL123451234512345:predict' \
--header 'Accept-Charset: utf-8' \
--header 'Authorization: Bearer abcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcdabcd' \
--header 'Content-Type: application/json' \
--data-raw '{
"payload": {
"row": {
"values": [
"yes",
"-1",
"primary",
"jul",
"51",
"0",
"yes",
"no",
"88",
"cellular",
"blue-collar",
"unknown",
"10",
"620",
"married"
]
}
}
}'

关于google-cloud-platform - 收到无效的 JSON 负载。未知名称\"row\"在 'payload' : Cannot find field on google automl api,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62742740/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com