Cet exemple de code peut être utilisé pour traduire du texte en mode de traitement par lot. Assurez-vous d'avoir effectué les étapes suivantes :
- Stockez votre fichier texte dans un bucket Cloud Storage source.
- Créez un bucket Cloud Storage cible pour stocker les fichiers texte traduits.
- Accordez aux comptes de service l'accès aux buckets Cloud Storage en plus des autorisations Cloud Translation.
Pour obtenir une collection complète d'exemples de code pour l'édition BTP SAP du SDK ABAP pour Google Cloud, consultez le dépôt d'exemples de code sur GitHub.
Pour obtenir une collection complète d'exemples de code pour l'édition sur site ou pour une édition cloud du SDK ABAP pour Google Cloud, consultez le dépôt d'exemples de code sur GitHub.
Exemple de code
Édition 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.
Sur site ou dans n'importe quelle édition cloud
**********************************************************************
* 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.