azure-ai-translation-ts

Créez des applications de traduction à l'aide des SDK Azure Translation pour JavaScript (`@azure-rest/ai-translation-text`, `@azure-rest/ai-translation-document`). À utiliser pour implémenter la traduction de texte, la translittération, la détection de langue ou la traduction de documents par lots.

npx skills add https://github.com/microsoft/skills --skill azure-ai-translation-ts

SDK Azure Translation pour TypeScript

Traduction de texte et de documents avec des clients de style REST.

Installation

# Traduction de texte
npm install @azure-rest/ai-translation-text @azure/identity

# Traduction de documents
npm install @azure-rest/ai-translation-document @azure/identity

Variables d'environnement

TRANSLATOR_ENDPOINT=https://api.cognitive.microsofttranslator.com
TRANSLATOR_SUBSCRIPTION_KEY=<your-api-key>
TRANSLATOR_REGION=<your-region>  # ex. westus, eastus
AZURE_TOKEN_CREDENTIALS=prod # Requis seulement si DefaultAzureCredential est utilisé en production

Client de traduction de texte

Authentification

import TextTranslationClient, { TranslatorCredential } from "@azure-rest/ai-translation-text";

// Clé API + Région
const credential: TranslatorCredential = {
  key: process.env.TRANSLATOR_SUBSCRIPTION_KEY!,
  region: process.env.TRANSLATOR_REGION!,
};
const client = TextTranslationClient(process.env.TRANSLATOR_ENDPOINT!, credential);

// Ou simplement credential (utilise l'endpoint global)
const client2 = TextTranslationClient(credential);

Traduire du texte

import TextTranslationClient, { isUnexpected } from "@azure-rest/ai-translation-text";

const response = await client.path("/translate").post({
  body: {
    inputs: [
      {
        text: "Hello, how are you?",
        language: "en",  // source (optionnel, détection auto)
        targets: [
          { language: "es" },
          { language: "fr" },
        ],
      },
    ],
  },
});

if (isUnexpected(response)) {
  throw response.body.error;
}

for (const result of response.body.value) {
  for (const translation of result.translations) {
    console.log(`${translation.language}: ${translation.text}`);
  }
}

Traduire avec options

const response = await client.path("/translate").post({
  body: {
    inputs: [
      {
        text: "Hello world",
        language: "en",
        textType: "Plain",  // ou "Html"
        targets: [
          {
            language: "de",
            profanityAction: "NoAction",  // "Marked" | "Deleted"
            tone: "formal",  // spécifique aux LLM
          },
        ],
      },
    ],
  },
});

Obtenir les langues supportées

const response = await client.path("/languages").get();

if (isUnexpected(response)) {
  throw response.body.error;
}

// Langues de traduction
for (const [code, lang] of Object.entries(response.body.translation || {})) {
  console.log(`${code}: ${lang.name} (${lang.nativeName})`);
}

Translittération

const response = await client.path("/transliterate").post({
  body: { inputs: [{ text: "这是个测试" }] },
  queryParameters: {
    language: "zh-Hans",
    fromScript: "Hans",
    toScript: "Latn",
  },
});

if (!isUnexpected(response)) {
  for (const t of response.body.value) {
    console.log(`${t.script}: ${t.text}`);  // Latn: zhè shì gè cè shì
  }
}

Détecter la langue

const response = await client.path("/detect").post({
  body: { inputs: [{ text: "Bonjour le monde" }] },
});

if (!isUnexpected(response)) {
  for (const result of response.body.value) {
    console.log(`Language: ${result.language}, Score: ${result.score}`);
  }
}

Client de traduction de documents

Authentification

import DocumentTranslationClient from "@azure-rest/ai-translation-document";
import { DefaultAzureCredential, ManagedIdentityCredential } from "@azure/identity";

const endpoint = "https://<translator>.cognitiveservices.azure.com";

// Dev local : DefaultAzureCredential. Production : définir AZURE_TOKEN_CREDENTIALS=prod ou AZURE_TOKEN_CREDENTIALS=<specific_credential>
const credential = new DefaultAzureCredential({requiredEnvVars: ["AZURE_TOKEN_CREDENTIALS"]});
// Ou utiliser directement une credential spécifique en production :
// Voir https://learn.microsoft.com/javascript/api/overview/azure/identity-readme?view=azure-node-latest#credential-classes
// const credential = new ManagedIdentityCredential();

// TokenCredential
const client = DocumentTranslationClient(endpoint, credential);

// Clé API
const client2 = DocumentTranslationClient(endpoint, { key: "<api-key>" });

Traduction d'un seul document

import DocumentTranslationClient from "@azure-rest/ai-translation-document";
import { writeFile } from "node:fs/promises";

const response = await client.path("/document:translate").post({
  queryParameters: {
    targetLanguage: "es",
    sourceLanguage: "en",  // optionnel
  },
  contentType: "multipart/form-data",
  body: [
    {
      name: "document",
      body: "Hello, this is a test document.",
      filename: "test.txt",
      contentType: "text/plain",
    },
  ],
}).asNodeStream();

if (response.status === "200") {
  await writeFile("translated.txt", response.body);
}

Traduction par lot de documents

import { ContainerSASPermissions, BlobServiceClient } from "@azure/storage-blob";

// Générer les URL SAS pour les conteneurs source et cible
const sourceSas = await sourceContainer.generateSasUrl({
  permissions: ContainerSASPermissions.parse("rl"),
  expiresOn: new Date(Date.now() + 24 * 60 * 60 * 1000),
});

const targetSas = await targetContainer.generateSasUrl({
  permissions: ContainerSASPermissions.parse("rwl"),
  expiresOn: new Date(Date.now() + 24 * 60 * 60 * 1000),
});

// Démarrer la traduction par lot
const response = await client.path("/document/batches").post({
  body: {
    inputs: [
      {
        source: { sourceUrl: sourceSas },
        targets: [
          { targetUrl: targetSas, language: "fr" },
        ],
      },
    ],
  },
});

// Obtenir l'ID d'opération à partir de l'en-tête
const operationId = new URL(response.headers["operation-location"])
  .pathname.split("/").pop();

Obtenir le statut de la traduction

import { isUnexpected, paginate } from "@azure-rest/ai-translation-document";

const statusResponse = await client.path("/document/batches/{id}", operationId).get();

if (!isUnexpected(statusResponse)) {
  const status = statusResponse.body;
  console.log(`Status: ${status.status}`);
  console.log(`Total: ${status.summary.total}`);
  console.log(`Success: ${status.summary.success}`);
}

// Lister les documents avec pagination
const docsResponse = await client.path("/document/batches/{id}/documents", operationId).get();
const documents = paginate(client, docsResponse);

for await (const doc of documents) {
  console.log(`${doc.id}: ${doc.status}`);
}

Obtenir les formats supportés

const response = await client.path("/document/formats").get();

if (!isUnexpected(response)) {
  for (const format of response.body.value) {
    console.log(`${format.format}: ${format.fileExtensions.join(", ")}`);
  }
}

Types clés

// Traduction de texte
import type {
  TranslatorCredential,
  TranslatorTokenCredential,
} from "@azure-rest/ai-translation-text";

// Traduction de documents
import type {
  DocumentTranslateParameters,
  StartTranslationDetails,
  TranslationStatus,
} from "@azure-rest/ai-translation-document";

Bonnes pratiques

  1. Détection auto de la source - Omettez le paramètre language pour la détection automatique
  2. Requêtes par lot - Traduisez plusieurs textes en un seul appel pour l'efficacité
  3. Utiliser les tokens SAS - Pour la traduction de documents, utilisez des URL SAS à durée limitée
  4. Gérer les erreurs - Toujours vérifier isUnexpected(response) avant d'accéder au body
  5. Endpoints régionaux - Utilisez les endpoints régionaux pour une latence plus faible

Skills similaires