【问题标题】:GCP AutoML TextSnippet longer than 10.000 charactersGCP AutoML TextSnippet 超过 10.000 个字符
【发布时间】:2021-07-09 22:31:39
【问题描述】:

我一直在使用 GCP AUtoML Python 库 2.2.0 版进行文本提取,而且通常效果很好。但是有时它会给我这个错误:

    Traceback (most recent call last):
  File "/usr/local/lib/python3.6/site-packages/flask/app.py", line 2447, in wsgi_app
    response = self.full_dispatch_request()
  File "/usr/local/lib/python3.6/site-packages/flask/app.py", line 1952, in full_dispatch_request
    rv = self.handle_user_exception(e)
  File "/usr/local/lib/python3.6/site-packages/flask/app.py", line 1821, in handle_user_exception
    reraise(exc_type, exc_value, tb)
  File "/usr/local/lib/python3.6/site-packages/flask/_compat.py", line 39, in reraise
    raise value
  File "/usr/local/lib/python3.6/site-packages/flask/app.py", line 1950, in full_dispatch_request
    rv = self.dispatch_request()
  File "/usr/local/lib/python3.6/site-packages/flask/app.py", line 1936, in dispatch_request
    return self.view_functions[rule.endpoint](**req.view_args)
  File "/wr/api/simple_text_nlp.py", line 159, in extract_entity_from_text
    predict_data, predict_id, predict_error = extract_entity.predict(text, model_path)
  File "/usr/local/lib/python3.6/site-packages/ProfessorPatPending/ocr/textOperations.py", line 68, in predict
    response = self.__client.predict(name=model_path, payload=payload)
  File "/usr/local/lib/python3.6/site-packages/google/cloud/automl_v1/services/prediction_service/client.py", line 498, in predict
    response = rpc(request, retry=retry, timeout=timeout, metadata=metadata,)
  File "/usr/local/lib/python3.6/site-packages/google/api_core/gapic_v1/method.py", line 145, in __call__
    return wrapped_func(*args, **kwargs)
  File "/usr/local/lib/python3.6/site-packages/google/api_core/grpc_helpers.py", line 75, in error_remapped_callable
    six.raise_from(exceptions.from_grpc_error(exc), exc)
  File "<string>", line 3, in raise_from
google.api_core.exceptions.InvalidArgument: 400 List of found errors:   1.Field: payload.text_snippet.content; Message: The provided string field value is longer than 10000: 10796

有问题的 TextSnippet 有超过 10.000 个字符,但 documentation 明确指出它最多可以有 250.000 个字符。谁能给我解释一下这是怎么回事?

创建文本sn-p的代码是:

client = automl.PredictionServiceClient.from_service_account_file(sa_json_file)    
text_snippet = automl.TextSnippet(content=text_data, mime_type="text/plain")
payload = automl.ExamplePayload(text_snippet=text_snippet)
response = client.predict(name=model_path, payload=payload)

出于显而易见的原因,我不会在此处发布 text_data 本身。

谢谢。

【问题讨论】:

    标签: python-3.x google-cloud-platform google-cloud-automl


    【解决方案1】:

    您遇到的错误是在 client.predict() 上,因为您发送的 TextSnippet 大于 10k 个字符。 AutoML Entity Extraction 每个预测请求仅限 10k 个字符。

    AutoML 自然语言实体提取

    • 文本片段最多 10,000 个字符,UTF-8 NFC 编码或 .PDF、.TIF 或 .TIFF 格式的文档,大小不超过 20MB。

    我建议您拆分 TextSnippet 并发送多个请求或将 TextSnippet 修剪为 10k 以满足字符限制。

    【讨论】:

    • 感谢您的反馈,我会更新看看是否有效。
    猜你喜欢
    • 2022-08-16
    • 1970-01-01
    • 2021-04-14
    • 2023-03-15
    • 1970-01-01
    • 1970-01-01
    • 2021-06-09
    • 2015-03-14
    • 1970-01-01
    相关资源
    最近更新 更多