Can I inlude an id field in Azure Translator requests?

steve corman 15 Reputation points
2024-06-13T00:06:31.1666667+00:00

I would like to include an id field in the json string contained in the Azure Translator API request that would get passed back with the result. This is so I can put the translated text back into the correct record of a database. Chat GPT-4o thinks I can do this, but I thought I'd better verify. I don't see any reference to it in the docs.

Azure Translator
Azure Translator
An Azure service to easily conduct machine translation with a simple REST API call.
411 questions
{count} votes

1 answer

Sort by: Most helpful
  1. navba-MSFT 24,905 Reputation points Microsoft Employee
    2024-06-13T06:56:40.4466667+00:00

    @steve corman Welcome to Microsoft Q&A Forum, Thank you for posting your query here!

    .

    I was able to achieve this via the Translate REST API by sending custom id like below:

    {"id": 1, "text": "Hello, world!"}, {"id": 2, "text": "Good morning!"}

    I am sharing the below Python code if that helps:

    import requests
    import json
    
    # Define your subscription key and region
    subscription_key = 'a4b6a7XXXXXXXXXXXdec50'
    region = 'eastus'
    
    # Define the endpoint URL
    endpoint = 'https://api.cognitive.microsofttranslator.com/translate'
    params = {
        'api-version': '3.0',
        'to': 'de'
    }
    
    # Define the headers
    headers = {
        'Ocp-Apim-Subscription-Key': subscription_key,
        'Ocp-Apim-Subscription-Region': region,
        'Content-Type': 'application/json'
    }
    
    # Define your translation requests with custom IDs
    translation_requests = [
        {"id": 1, "text": "Hello, world!"},
        {"id": 2, "text": "Good morning!"}
    ]
    
    # Extract the texts to be translated
    texts = [{"text": req["text"]} for req in translation_requests]
    
    # Make the POST request
    response = requests.post(endpoint, params=params, headers=headers, data=json.dumps(texts))
    
    # Check if the request was successful
    if response.status_code == 200:
        translations = response.json()
        # Add the IDs back to the translations based on the order of the requests
        for i, translated_text in enumerate(translations):
            translated_text['id'] = translation_requests[i]['id']
        print(json.dumps(translations, indent=4))
    else:
        print(f"Error: {response.status_code}")
        print(response.text)
    

    .

    I received response like below:

    [
    
        {
    
            "detectedLanguage": {
    
                "language": "en",
    
                "score": 1.0
    
            },
    
            "translations": [
    
                {
    
                    "text": "Hallo Welt!",
    
                    "to": "de"
    
                }
    
            ],
    
            "id": 1
    
        },
    
        {
    
            "detectedLanguage": {
    
                "language": "en",
    
                "score": 1.0
    
            },
    
            "translations": [
    
                {
    
                    "text": "Guten Morgen!",
    
                    "to": "de"
    
            "id": 2
    
        }
    
    ]
    

    By using the above approach, you can ensure that the translated texts are correctly associated with their corresponding records in your database, even if the API itself doesn't support custom fields directly in the request and response.

    .

    Hope this helps. If you have any follow-up questions, please let me know. I would be happy to help.

    0 comments No comments

Your answer

Answers can be marked as Accepted Answers by the question author, which helps users to know the answer solved the author's problem.