12
7

More than 1 year has passed since last update.

Power Automate for desktop からの DeepL API 使用方法

Last updated at Posted at 2021-12-19

はじめに

この記事では、Power Automate for desktop (PAD) から、DeepL API を使用して翻訳の自動化を行うためのサンプルを記載しています。

Web API アドベントカレンダー 19 日目の記事です。

DeepL API を利用するには

DeepL API には、無料の DeepL API Free プランがあります。
DeepL API Free プランの説明や DeepL API Free プランの利用を開始するには以下の記事の "DeepL API の利用方法" をご確認ください。

Power Automate for desktop からの DeepL API 使用方法

フローの全体像

Power Automate for desktop では、"Web サービスを呼び出します" アクション (Invoke Web Service) を使用して、Web API を使用することができます。
"Web サービスを呼び出します" アクションを使って、DeepL API を利用する方法を記載します。

今回作成するフローの全体像は以下の通りです。
image.png

各アクションを見ていきます。

1. "入力ダイアログ"の表示アクションの設定

翻訳する文字を入力するメッセージボックスを表示します。

メッセージボックスに入力された文字は、生成された変数に設定されますので、この変数名を %TranslateWord% という名前に設定します。

image.png

2. "Web サービスを呼び出します" アクションの設定

DeepL API を実行するために "Web サービスを呼び出します" アクション必要な設定を入力します。

このアクションで、重要なポイントは、要求本文の項目に以下の内容を文字列連結します。
・auth_key には、DeepL のAPI 認証キーを設定します。
・text には、メッセージボックスで入力した文字列が入った変数 %TranslateWord% を設定します
・target_lang には、今回は日本語への変換なので JA を指定します。

上記を踏まえた各パラメータの設定は以下の通りです。

プロパティ パラメータ
URI https://api-free.deepl.com/v2/translate
メソッド POST
受け入れる application/json
コンテンツタイプ application/x-www-form-urlencoded
要求本文 auth_key="DeepL の API キー"&text=%TranslateWord%&target_lang=JA
要求本文をエンコードします オフ

設定後のイメージ

image.png

返却される値については、[生成された変数] の "Web サービスの応答テキスト" に設定されますので、この変数名を %DeepLResponse% という名前に設定します。

image.png

3. "JSON をカスタムオブジェクトに変換" アクションの設定

DeepL API から変換される値は以下のような JSON 形式の文字列です。

image.png

この文字列を PAD 上で扱いやすくするために "JSON をカスタムオブジェクトに変換" アクションで、変換します。
API の実行結果が格納されている %DeepLResponse% を %DeepLCustomObject% という変数に変換します。
image.png

変換されたカスタムオブジェクトの内容は以下の通りの構造のデータとして確認することができるようになります。見やすい。
image.png

4. "メッセージを表示" アクションの設定

最後に翻訳された文字をメッセージボックスに表示します。
%DeepLCustomObject% は、上記の通り、カスタムオブジェクトに格納されているので、カスタムオブジェクトの構造にアクセスし、値を取得します。

どんな構造かわからないという場合は、DeepL API の応答の仕様やフローデザイナーのフロー変数からカスタム オブジェクトの変数を表示し、詳細表示をクリックすることで、アクセスする構造を確認することができます。
image.png

上記で確認した構造の結果(%DeepLCustomObject['translations'][0]['text']%)を表示するメッセージに設定します。
image.png

実行結果

文字が欠けて表示されていますが、以下のようにメッセージボックスに入力した文字列が翻訳されて表示されます。

<翻訳前>
Power Automate for desktop broadens the existing robotic process automation (RPA) capabilities in Power Automate and enables you to automate all repetitive desktop processes.
image.png

<翻訳後>
Power Automate for desktopは、Power Automateの既存のRPA(ロボティック・プロセス・オートメーション)機能を拡張し、反復的なデスクトッププロセスをすべて自動化することができます。
image.png

おわりに

DeepL API は、開発者用の Free プランもあり、とても試しやすいです。
また、リクエストも応答もシンプルで、私のような API 初心者でも簡単に使用することができました。
今回は、文字入力したもの翻訳する処理を行いましたが、Excel などのドキュメントに入力された文字列を翻訳するなど様々な用途があると思います。

12
7
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
12
7