Menerjemahkan dokumen dalam mode batch

Contoh kode ini dapat digunakan untuk menerjemahkan satu atau beberapa file dari jenis yang didukung di bucket Cloud Storage dan menyimpan file yang diterjemahkan ke dalam bucket Cloud Storage target. Untuk terjemahan batch, akun layanan harus memiliki izin tambahan untuk mengakses bucket Cloud Storage beserta izin untuk melakukan terjemahan. Untuk informasi selengkapnya, lihat Menerjemahkan dokumen.

Untuk melihat kumpulan lengkap contoh kode ABAP SDK untuk Google Cloud, lihat repositori GoogleCloudPlatform/google-cloud-abap/abap-sdk /ZPrestaShop_SDK_DOCS_EXAMPLES di GitHub.

Contoh kode

**********************************************************************
*  Copyright 2023 Google LLC                                         *
*                                                                    *
*  Licensed under the Apache License, Version 2.0 (the "License");   *
*  you may not use this file except in compliance with the License.  *
*  You may obtain a copy of the License at                           *
*      https://www.apache.org/licenses/LICENSE-2.0                   *
*  Unless required by applicable law or agreed to in writing,        *
*  software distributed under the License is distributed on an       *
*  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,      *
*  either express or implied.                                        *
*  See the License for the specific language governing permissions   *
*  and limitations under the License.                                *
**********************************************************************

REPORT zr_batch_translate_document_lo.

* Data Declarations
DATA:
  lv_p_projects_id  TYPE string,
  lv_p_locations_id TYPE string,
  ls_input          TYPE /goog/cl_translation_v3=>ty_003,
  lo_exception      TYPE REF TO /goog/cx_sdk.

TRY.
*     Open HTTP Connection
    "Pass the configured client key to be used
    DATA(lo_translate) = NEW /goog/cl_translation_v3( iv_key_name = 'TRANSLATE_DEMO' ).

    "Populate the data that needs to be passed to the api
    "Derive project id
    lv_p_projects_id  = lo_translate->gv_project_id.
    "Pass location id, us-central1 is used as an example
    lv_p_locations_id = 'us-central1'.

    "Passing two target language codes (BCP-47 codes)
    "Input URI and Outpur URI contain example cloud storage bucket names
    ls_input = VALUE #( source_language_code = 'en-US'
                        target_language_codes = VALUE #( ( `es-ES` )
                                                         ( `fr-FR` ) )
                        input_configs = VALUE #( ( gcs_source =
                                                 VALUE #( input_uri = 'gs://documents/batch' ) ) )
                        output_config = VALUE #( gcs_destination =
                                                 VALUE #( output_uri_prefix = 'gs://documents_output/' ) )
                       ).

*     Call the API
    CALL METHOD lo_translate->batch_translate_document_lo
      EXPORTING
        iv_p_projects_id  = lv_p_projects_id
        iv_p_locations_id = lv_p_locations_id
        is_input          = ls_input
      IMPORTING
        es_output         = DATA(ls_output)
        ev_ret_code       = DATA(lv_ret_code)
        ev_err_text       = DATA(lv_err_text)
        es_err_resp       = DATA(ls_err_resp).
    IF /goog/cl_http_client=>is_success( lv_ret_code ).
*       This returns a long running operation id as glossary creation is adhoc
*       You can use the LRO ID to poll and check the status of the operation
      WRITE: 'LRO ID:', ls_output-name.
    ELSE.
      MESSAGE lv_err_text TYPE 'E'.
    ENDIF.

*     Close HTTP Connection
    lo_translate->close( ).

  CATCH /goog/cx_sdk INTO lo_exception.
    lv_err_text = lo_exception->get_text( ).
ENDTRY.