REST API をプログラムで使用する

ドキュメント翻訳は、Azure AI 翻訳サービスのクラウドベースの機能です。 ドキュメント翻訳 API を使用すると、ソース ドキュメントの構造とテキストの書式設定を維持しながら、サポートされている言語とさまざまなファイル形式でドキュメント全体を非同期的に翻訳できます。 この攻略ガイドでは、任意のプログラミング言語と HTTP REST API でドキュメント翻訳 API を使用する方法について説明します。

前提条件

Note

  • 通常、Azure portal で Azure AI リソースを作成するときは、マルチサービスのキーまたは単一サービスのキーを作成するという選択肢があります。 ただし、ドキュメント翻訳は現在 Translator (単一サービス) リソースでのみサポートされているため、Azure AI サービス (マルチサービス) リソースには含まれていません

  • ドキュメント翻訳は、S1 Standard サービス プラン (従量課金制) および C2、C3、C4、D3 ボリューム割引プランでサポートされています。 「Azure AI サービスの価格 - Translator」をご覧ください。

開始するには、以下が必要です。

  • アクティブな Azure アカウント。 アカウントがない場合は、無料アカウントを作成できます

  • Azure Blob Storage アカウント。 Azure Blob Storage アカウント内に、ソースとターゲットの各ファイル用のコンテナーを作成する必要があります。

    • ソースのコンテナー。 このコンテナーは、翻訳対象のファイルをアップロードする場所です (必須)。
    • ターゲットのコンテナー。 このコンテナーは、翻訳されたファイルを格納する場所です (必須)。
  • 単一サービス Translator リソース (マルチサービス Azure AI サービス リソースとは異なる):

    次のように、Translator プロジェクトとインスタンスの詳細フィールドを入力します。

    1. [サブスクリプション]。 使用できる Azure サブスクリプションのいずれかを選択します。

    2. [リソース グループ]。 新しいリソース グループを作成するか、同じライフサイクル、アクセス許可、ポリシーを共有する既存のリソース グループにリソースを追加することができます。

    3. [リソース リージョン] . ご自身のビジネスまたはアプリケーションが特定のリージョンを必要としない限り、 [グローバル] を選択します。 認証にシステム割り当てマネージド ID を使用する場合は、米国西部などの地理的リージョンを選択します。

    4. 名前。 リソースに選んだ名前を入力します。 選択した名前は Azure 内で一意である必要があります。

      Note

      ドキュメント翻訳には、カスタム ドメイン エンドポイントが必要です。 名前フィールドに入力する値は、エンドポイントのカスタム ドメイン名となります。

    5. 価格レベル。 ドキュメント翻訳は、Free レベルではサポートされません。 このサービスを試すには、Standard S1 を選択してください。

    6. [確認および作成] を選択します。

    7. サービス条件を確認し、 [作成] を選択してリソースをデプロイします。

    8. リソースが正常にデプロイされたら、[リソースに移動] を選択してキーとエンドポイントを取得します。

キーとカスタム ドメイン エンドポイントを取得する

  • Translator サービスへの要求では、アクセスを認証するために読み取り専用キーとカスタム エンドポイントが必要です。 カスタム ドメイン エンドポイントは、リソース名、ホスト名、Translator サブディレクトリを指定した形式の URL であり、Azure portal で使用できます。
  1. 新しいリソースを作成した場合は、そのデプロイ後に [リソースに移動] を選びます。 既存のドキュメント翻訳リソースがある場合は、リソース ページに直接移動します。

  2. 左側のレールの [リソース管理] で、 [キーとエンドポイント] を選択します。

  3. 自分の keydocument translation endpoint をコピーして、使いやすい場所 ("Microsoft メモ帳" など) に貼り付けます。 API 呼び出しを行うために必要なキーは 1 つだけです。

  4. keydocument translation endpoint を、ドキュメント翻訳サービスへの要求の認証のためのコード サンプルに貼り付けます。

    Azure portal の [キーの取得] フィールドを示すスクリーンショット。

キーを取得する

Translator サービスへの要求には、アクセス認証を受けるための読み取り専用キーが必要です。

  1. 新しいリソースを作成した場合は、そのデプロイ後に [リソースに移動] を選びます。 既存のドキュメント翻訳リソースがある場合は、リソース ページに直接移動します。
  2. 左側のレールの [リソース管理] で、 [キーとエンドポイント] を選択します。
  3. 自分のキーをコピーして、使いやすい場所 ("Microsoft メモ帳" など) に貼り付けます。
  4. それを、ドキュメント翻訳サービスへの要求の認証のための次のコード サンプルに貼り付けます。

Azure portal のキーを取得するフィールドを示す画像。

Azure Blob Storage コンテナーを作成する

Azure Blob Storage アカウント内に、ソースおよびターゲットの各ファイル用のコンテナーを作成する必要があります。

  • ソースのコンテナー。 このコンテナーは、翻訳対象のファイルをアップロードする場所です (必須)。
  • ターゲットのコンテナー。 このコンテナーは、翻訳されたファイルを格納する場所です (必須)。

Note

ドキュメント翻訳では、用語集は、個別の用語集コンテナーではなく、ターゲット コンテナー内の BLOB としてサポートされます。 カスタム用語集を含める場合は、それをターゲット コンテナーに追加し、要求に glossaryUrl を含める必要があります。 翻訳言語のペアが用語集に存在しない場合、それは適用されません。 「カスタム用語集を使用してドキュメントを翻訳する」を "参照してください"

ドキュメント翻訳用の SAS アクセス トークンを作成する

sourceUrltargetUrl、省略可能な glossaryUrl には Shared Access Signature (SAS) トークンを含める必要があり、クエリ文字列として追加します。 トークンは、コンテナーまたは特定の BLOB に割り当てることができます。 「ドキュメント翻訳プロセスの SAS トークンを作成する」を "参照してください"。

  • ソースのコンテナーまたは BLOB には、読み取り一覧表示のアクセス権が指定されている必要があります。
  • ターゲットのコンテナーまたは BLOB には、書き込み一覧表示のアクセス権が指定されている必要があります。
  • 用語集の BLOB には、読み取り一覧表示のアクセス権が指定されている必要があります。

ヒント

  • 操作で複数のファイル (BLOB) を翻訳する場合は、コンテナー レベルで SAS アクセス権を委任します。
  • 操作で 1 つ のファイル (BLOB) を翻訳する場合は、BLOB レベルで SAS アクセス権を委任します。
  • SAS トークンの代わりに、システム割り当てマネージド ID を認証に使用することができます。

HTTP 要求

非同期バッチ翻訳要求は、POST 要求を通じて Translator サービス エンドポイントに送信されます。 成功した場合、POST メソッドから 202 Accepted 応答コードが返され、サービスによってバッチ要求が作成されます。 翻訳されたドキュメントがターゲット コンテナーに一覧表示されます。

Azure AI 翻訳サービスの要求の制限について詳しくは、ドキュメント翻訳の要求の制限に関する記事をご覧ください

HTTP ヘッダー

各 Document Translation API 要求には、次のヘッダーが含まれています。

HTTP ヘッダー 説明
Ocp-Apim-Subscription-Key 必須: 値は、Translator または Azure AI サービス リソースの Azure キーです。
Content-Type 必須: ペイロードのコンテンツ タイプを指定します。 許容される値は、application/json または charset=UTF-8 です。

POST 要求本文のプロパティ

  • Post 要求の URL は POST https://<NAME-OF-YOUR-RESOURCE>.cognitiveservices.azure.com/translator/text/batch/v1.1/batches です。
  • POST 要求本文は、inputs という名前の JSON オブジェクトです。
  • inputs オブジェクトには、ソースとターゲットの言語ペア用の sourceURLtargetURL のコンテナー アドレスが両方とも含まれています。
  • prefixsuffix は、翻訳対象のソース パス内のドキュメントをフィルター処理するための、大文字と小文字を区別する文字列です。 prefix フィールドは、翻訳用のサブフォルダーを表現するためによく使われます。 suffix フィールドは、ファイルの拡張子に最もよく使われます。
  • glossaries フィールド (省略可能) の値は、ドキュメントが翻訳されるときに適用されます。
  • 各ターゲット言語の targetUrl は一意でなければなりません。

Note

同じ名前のファイルが宛先に既に存在する場合、ジョブは失敗します。

コンテナー内のすべてのドキュメントを翻訳する

{
    "inputs": [
        {
            "source": {
                "sourceUrl": "{sourceSASUrl}"
            },
            "targets": [
                {
                    "targetUrl": "{targetSASUrl}",
                    "language": "fr"
                }
            ]
        }
    ]
}

コンテナー内の特定のドキュメントを翻訳する

  • "storageType": "File" を指定します。
  • システム割り当てマネージド ID を認証に使っていない場合は、(コンテナーではなく) 特定の BLOB またはドキュメントに対して、ソース URL と SAS トークンが作成されていることを確認してください。
  • ターゲット URL の一部としてターゲット ファイル名が指定されていることを確認してください (ただし、SAS トークンはコンテナー用のままです)。
  • サンプル要求では、1 つのドキュメントが 2 つのターゲット言語に翻訳されたものが返されます。
{
    "inputs": [
        {
            "storageType": "File",
            "source": {
                "sourceUrl": "{sourceSASUrl}"
            },
            "targets": [
                {
                    "targetUrl": "{targetSASUrl}",
                    "language": "es"
                },
                {
                    "targetUrl": "{targetSASUrl}",
                    "language": "de"
                }
            ]
        }
    ]
}

カスタム用語集を使用してドキュメントを翻訳する

{
    "inputs": [
        {
            "source": {
                "sourceUrl": "{sourceSASUrl}"
             },
            "targets": [
                {
                    "targetUrl": "{targetSASUrl}",
                    "language": "es",
                    "glossaries": [
                        {
                            "glossaryUrl": "{glossaryUrl/en-es.xlf}",
                            "format": "xliff"
                        }
                    ]
                }
            ]
        }
    ]
}

コードを使用してドキュメント翻訳要求を送信する

コーディング プラットフォームを設定する

  • 新しいプロジェクトを作成します。
  • Program.cs を C# コード サンプルで置き換えます。
  • エンドポイント、キー、コンテナー URL の値を Program.cs に設定します。
  • JSON データを処理するために、.NET CLI を使用して Newtonsoft.Json パッケージを追加します。
  • プロジェクト ディレクトリからプログラムを実行します。

重要

コード サンプルでは、示されている場所に Shared Access Signature (SAS) URL をハードコーディングします。 終了したら、コードから SAS の URL を削除し、決して公開しないようにしてください。 本番環境では、Azure マネージド ID のような、資格情報を安全に保存してアクセスできる方法を使用してください。 詳細については、「Azure Storage のセキュリティ」を参照してください

操作によっては、次のフィールドの更新が必要になる場合があります。

  • endpoint
  • basePath
  • key
  • sourceURL
  • targetURL
  • glossaryURL
  • id (ジョブ ID)

id 値の検索

  • ジョブ id は、POST start-batch-translation メソッドの応答ヘッダー Operation-Location の URL 値で確認します。 /document/ パラメーターの後に続く英数字の文字列は、操作のジョブ id です。
応答ヘッダー 応答 URL
Operation-Location {document-translation-endpoint}/translator/document/9dce0aa9-78dc-41ba-8cae-2e2f3c2ff8ec?api-version={date}
  • また、get-translations-status 要求を使用して、翻訳 "ジョブ" とその id の一覧を取得することもできます。

非同期バッチ翻訳を開始する


    using System;
    using System.Net.Http;
    using System.Threading.Tasks;
    using System.Text;


    class Program
    {

        static readonly string route = "?api-version={date}";

        private static readonly string basePath = "{your-document-translation-endpoint}/translator/document/batches";

        private static readonly string key = "{your-api-key}";

        static readonly string json = ("{\"inputs\": [{\"source\": {\"sourceUrl\": \"https://YOUR-SOURCE-URL-WITH-READ-LIST-ACCESS-SAS\",\"storageSource\": \"AzureBlob\",\"language\": \"en\"}, \"targets\": [{\"targetUrl\": \"https://YOUR-TARGET-URL-WITH-WRITE-LIST-ACCESS-SAS\",\"storageSource\": \"AzureBlob\",\"category\": \"general\",\"language\": \"es\"}]}]}");

        static async Task Main(string[] args)
        {
            using HttpClient client = new HttpClient();
            using HttpRequestMessage request = new HttpRequestMessage();
            {

                StringContent content = new StringContent(json, Encoding.UTF8, "application/json");

                request.Method = HttpMethod.Post;
                request.RequestUri = new Uri(basePath + route);
                request.Headers.Add("Ocp-Apim-Subscription-Key", key);
                request.Content = content;

                HttpResponseMessage  response = await client.SendAsync(request);
                string result = response.Content.ReadAsStringAsync().Result;
                if (response.IsSuccessStatusCode)
                {
                    Console.WriteLine($"Status code: {response.StatusCode}");
                    Console.WriteLine();
                    Console.WriteLine($"Response Headers:");
                    Console.WriteLine(response.Headers);
                }
                else
                    Console.Write("Error");

            }

        }

    }

サポートされるドキュメントの形式の取得

サポートされているファイル形式の一覧を取得します。 成功した場合、このメソッドから 200 OK 応答コードが返されます。


using System;
using System.Net.Http;
using System.Threading.Tasks;


class Program
{


    private static readonly string basePath = "{your-document-translation-endpoint}/translator/document/formats";

    static readonly string route = "?api-version={date}&type=document";

    private static readonly string key = "{your-api-key}";

    static async Task Main(string[] args)
    {

        HttpClient client = new HttpClient();
            using HttpRequestMessage request = new HttpRequestMessage();
            {
                request.Method = HttpMethod.Get;
                request.RequestUri = new Uri(basePath + route);
                request.Headers.Add("Ocp-Apim-Subscription-Key", key);


                HttpResponseMessage response = await client.SendAsync(request);
                string result = response.Content.ReadAsStringAsync().Result;

                Console.WriteLine($"Status code: {response.StatusCode}");
                Console.WriteLine($"Response Headers: {response.Headers}");
                Console.WriteLine();
                Console.WriteLine(result);
            }
}

翻訳ジョブの状態を取得する

1 つのジョブの現在の状態と、ドキュメント翻訳要求に含まれるすべてのジョブの概要を取得します。 成功した場合、このメソッドから 200 OK 応答コードが返されます。


using System;
using System.Net.Http;
using System.Threading.Tasks;


class Program
{


    private static readonly string basePath = "{your-document-translation-endpoint}/translator/document/batches/{id}";

    static readonly string route = "?api-version={date}";

    private static readonly string key = "{your-api-key}";

    static async Task Main(string[] args)
    {

        HttpClient client = new HttpClient();
            using HttpRequestMessage request = new HttpRequestMessage();
            {
                request.Method = HttpMethod.Get;
                request.RequestUri = new Uri(basePath + route);
                request.Headers.Add("Ocp-Apim-Subscription-Key", key);


                HttpResponseMessage response = await client.SendAsync(request);
                string result = response.Content.ReadAsStringAsync().Result;

                Console.WriteLine($"Status code: {response.StatusCode}");
                Console.WriteLine($"Response Headers: {response.Headers}");
                Console.WriteLine();
                Console.WriteLine(result);
            }
    }
}

特定のドキュメントの状態を取得する

概要

ドキュメント翻訳要求内の特定のドキュメントの状態を取得します。 成功した場合、このメソッドから 200 OK 応答コードが返されます。


using System;
using System.Net.Http;
using System.Threading.Tasks;


class Program
{


    private static readonly string basePath = "{document-translation-endpoint}/translator/document/batches/{id}/documents/{documentId}";

    static readonly string route = "?api-version={date}";

    private static readonly string key = "{your-api-key}";

    static async Task Main(string[] args)
    {

        HttpClient client = new HttpClient();
            using HttpRequestMessage request = new HttpRequestMessage();
            {
                request.Method = HttpMethod.Get;
                request.RequestUri = new Uri(basePath + route);
                request.Headers.Add("Ocp-Apim-Subscription-Key", key);


                HttpResponseMessage response = await client.SendAsync(request);
                string result = response.Content.ReadAsStringAsync().Result;

                Console.WriteLine($"Status code: {response.StatusCode}");
                Console.WriteLine($"Response Headers: {response.Headers}");
                Console.WriteLine();
                Console.WriteLine(result);
            }
}

ジョブを削除する

概要

現在処理中またはキューに入っているジョブをキャンセルします。 翻訳が開始されていないドキュメントだけがキャンセルされます。


using System;
using System.Net.Http;
using System.Threading.Tasks;


class Program
{


    private static readonly string basePath = "{your-document-translation-endpoint}/translator/document/batches/{id}";

    static readonly string route = "?api-version={date}";

    private static readonly string key = "{your-api-key}";

    static async Task Main(string[] args)
    {

        HttpClient client = new HttpClient();
            using HttpRequestMessage request = new HttpRequestMessage();
            {
                request.Method = HttpMethod.Delete;
                request.RequestUri = new Uri(basePath + route);
                request.Headers.Add("Ocp-Apim-Subscription-Key", key);


                HttpResponseMessage response = await client.SendAsync(request);
                string result = response.Content.ReadAsStringAsync().Result;

                Console.WriteLine($"Status code: {response.StatusCode}");
                Console.WriteLine($"Response Headers: {response.Headers}");
                Console.WriteLine();
                Console.WriteLine(result);
            }
}

一般的な HTTP 状態コード

HTTP 状態コード 説明 考えられる理由
200 OK 要求は成功しました。
400 正しくない要求 必須パラメーターが指定されていない、空、または null です。 または、必須またはオプションのパラメーターに渡された値が無効です。 よくある問題はヘッダーが長すぎることです。
401 権限がありません 要求は承認されません。 キーまたはトークンが有効であり、正しいリージョンにあることを確認してください。 Azure portal でサブスクリプションを管理する場合、Azure AI サービス マルチサービス リソースではなくTranslator 単一サービス リソースを使用していることを確認してください。
429 要求が多すぎます 使用中のサブスクリプションで許可されている要求のクォータまたは速度を超えています。
502 無効なゲートウェイ ネットワークまたはサーバー側の問題です。 無効なヘッダーを示す場合もあります。

詳細情報

次のステップ