일괄 모드에서 텍스트 번역

이 코드 샘플을 사용하여 일괄 모드에서 텍스트를 번역할 수 있습니다. 다음 단계를 완료했는지 확인합니다.

  • 텍스트 파일을 소스 Cloud Storage 버킷에 저장합니다.
  • 번역된 텍스트 파일을 저장할 대상 Cloud Storage 버킷을 만듭니다.
  • 서비스 계정에 Cloud Translation 권한 외에도 Cloud Storage 버킷에 대한 액세스 권한을 부여합니다.

ABAP SDK for Google Cloud의 SAP BTP 버전에 대한 코드 샘플 전체 컬렉션을 보려면 GitHub의 코드 샘플 저장소를 참조하세요.

온프레미스 또는 ABAP SDK for Google Cloud의 모든 클라우드 버전에 대한 코드 샘플 전체 컬렉션을 보려면 GitHub의 코드 샘플 저장소를 참조하세요.

코드 샘플

SAP BTP 버전

" --------------------------------------------------------------------
"  Copyright 2024 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.                                -
" --------------------------------------------------------------------
CLASS zcl_cs_translate_batch_mode DEFINITION
  PUBLIC FINAL
  CREATE PUBLIC.

  PUBLIC SECTION.
    INTERFACES if_oo_adt_classrun.
ENDCLASS.


CLASS zcl_cs_translate_batch_mode IMPLEMENTATION.
  METHOD if_oo_adt_classrun~main.
    " Data Declarations
    DATA lv_p_projects_id  TYPE string.
    DATA lv_p_locations_id TYPE string.
    DATA ls_input          TYPE /goog/cl_translation_v3=>ty_004.
    DATA ls_ip_cnf         TYPE /goog/cl_translation_v3=>ty_029.
    DATA lt_ip_cnf         TYPE /goog/cl_translation_v3=>ty_t_029.
    DATA ls_op_cnf         TYPE /goog/cl_translation_v3=>ty_043.
    DATA lv_folder         TYPE string.

    TRY.
        " Open HTTP Connection
        " Pass the configured client key
        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'.

        ls_input = VALUE #( input_configs         = VALUE #(
                                ( gcs_source = VALUE #( input_uri = 'gs://test_translation_ip/Test_File.txt' )
                                  mime_type  = 'text/plain' ) )
                            output_config         = VALUE #(
                                gcs_destination = VALUE #( output_uri_prefix = 'gs://test_translation_op/' )  )
                            source_language_code  = `en`
                            target_language_codes = VALUE #( ( `es` ) ) ).

        " Call the API
        lo_translate->batch_translate_text_locati( 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
          out->write( |LRO ID: { ls_output-name }| ).
        ELSE.
          out->write( | Error occurred: { lv_err_text }| ).
        ENDIF.

        " Close HTTP Connection
        lo_translate->close( ).

      CATCH /goog/cx_sdk INTO DATA(lo_sdk_excp).
        lv_err_text = lo_sdk_excp->get_text( ).
        out->write( |Exception occurred: { lv_err_text } | ).
    ENDTRY.
  ENDMETHOD.
ENDCLASS.

온프레미스 또는 모든 클라우드 버전

**********************************************************************
*  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_text_locati.

* Data Declarations
DATA:
  lv_p_projects_id  TYPE string,
  lv_p_locations_id TYPE string,
  ls_input          TYPE /goog/cl_translation_v3=>ty_004,
  lo_exception      TYPE REF TO /goog/cx_sdk,
  ls_ip_cnf         TYPE /goog/cl_translation_v3=>ty_029,
  lt_ip_cnf         TYPE /goog/cl_translation_v3=>ty_t_029,
  ls_op_cnf         TYPE /goog/cl_translation_v3=>ty_043,
  lv_folder         TYPE string.

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'.


    ls_input = VALUE #( input_configs =
                        VALUE #( ( gcs_source = VALUE #( input_uri = 'gs://test_translation_ip/Test_File.txt' )
                                   mime_type = 'text/plain' ) )
                         output_config =
                         VALUE #( gcs_destination =  VALUE #( output_uri_prefix = 'gs://test_translation_op/' )  )
                         source_language_code = `en`
                         target_language_codes =
                         VALUE #( ( `es` ) )
                         ).


*     Call the API
    CALL METHOD lo_translate->batch_translate_text_locati
      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.