BLOGスタッフブログ

システムエンジニア

Akihiro Shinozaki

2021.10.20 システム

DeepL翻訳のAPIを試してみました

こんにちは。

今回はDeepL翻訳のAPIを試してみましたので、簡単ですが導入方法についてご紹介したいと思います。

DeepL翻訳とは

DeepL翻訳
https://www.deepl.com/translator

2017年にサービス開始されたオンラインの翻訳サービスで、精度の高い翻訳を行ってくれます。
機械学習の技術を取り入れることで、自然な翻訳を実現しているようです。

deepl_1

私も海外QAサイトを調べる時や、英語で書かれたリファレンスの翻訳等
普段の業務で大いに活用させてもらっています。

APIの認証キーを準備する

APIを使用するためには認証キーが必要となります。
以下のページからユーザ登録を行い、認証キーを入手します。
(登録完了後のアカウント情報画面で「DeepL APIで使用する認証キー」が確認できます。)

https://www.deepl.com/ja/pro-api?cta=header-pro/

無料で使えるプラン(DeepL API Free)があるので、使用感等を簡単に試すことができます。
無料プランは1か月あたり500,000文字の制限はありますが、ちょっとした検証や個人で使用する分には十分ですね!

API呼び出しを試してみる

以下のリファレンスを参考にAPIの呼び出しを実装します。
https://www.deepl.com/ja/docs-api/translating-text/request/

シンプルな翻訳を行う場合は以下のパラメータをPOSTするだけなので、簡単ですね。
・auth_key:APIの認証キー
・text:翻訳したいテキスト
・target_lang:何語に翻訳するか(今回は日本語 → 英語に翻訳するので「EN」を指定します。)

サンプルコード(PHP)

  $param = array(
    'auth_key' => 'xxxx-xxxx-xxxx(認証キーをここに設定)',
    'text' => 'WEBで課題を解決します。',
    'target_lang' => 'EN'
  );
  $curl = curl_init("https://api-free.deepl.com/v2/translate");
  curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "POST");
  curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($param));
  curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
  curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
  curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); 

  $res = curl_exec($curl);
  curl_close($curl);

  var_dump(json_decode($res, true));

実行結果
deepl_2

今回はPHPからAPIの呼び出しを試してみました。
(翻訳結果を出力するだけの簡単なプログラムです。)

翻訳結果がJSON形式で返ってくるので、json_decodeで変換しています。
サンプルコードなのでエラーハンドリング等は考慮していませんが、期待通りの動作が確認できました。

APIを使うことで外部サービスと簡単に連携できます。
今回のAPIはサイトの多言語対応等に活用できそうですね。

ここまでお読みいただきありがとうございました。

Akihiro Shinozakiが書いた他の記事

見積もり・ご依頼など、
お気軽にご相談ください

本サイトはユーザーエクスペリエンスの向上などを目的に、Cookieを使用しています。
右記のバナーで「同意する」をクリックする、または本サイトを利用することにより、
お客様は弊社のCookieポリシーに同意したことになります。

同意します