8
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

#PowerApps と #PowerAutomate で プレビュー公開された #TextAnalytics の テキスト要約(summarize text)を実装してみた

Posted at

Azure の CogniticeServices の一つ、Text Analytics に先日、テキスト要約機能(Summarize Text)が実装されました。
How to: summarize text with Text Analytics (preview)

この機能・・・ビジネスアプリケーションにもめっちゃ使える奴やん!!

っていうことで、こんな感じで早速実装してみることにしました。

  • 3行要約の場合
    image.png

  • 7行要約の場合
    image.png

コネクタには・・・

そりゃありませんよね(笑)
image.png

閑話休題

Text Analytics APIの仕様を調べてみよう!

まぁこのページ、How to: summarize text with Text Analytics (preview)を見るのが一番早いんですが・・・

要約をする上で2種類のAPIを送信する必要があるようです。

Power Automate での作業

というわけで、Power AutomateでAPIの仕様に合わせて実装してみましょう。

処理要求API

https://<your-custom-subdomain>.cognitiveservices.azure.com/text/analytics/v3.2-preview.1/analyze

まずこのURLを使って、要約したい文章と文章の言語の指定、そして何行出力するのかといったことを指定するようです。

ちなみに詳しい仕様はこちらに書いてあります。

Text Analytics API (v3.2-preview.1)

なので、HTTPコネクタとしてはこういう設定になります。

image.png

で、実行すると、HTTPのヘッダーに、出力結果を問いあわせるURLが出力されます。

image.png

operation-location こいつが要求結果を取得するURLです。

なので、要求結果を取得するHTTPコネクタで使用できるように、ヘッダーをJSON解析をします。

image.png

JSONのスキーマ情報書いときますねー\( 'ω')/

{
    "type": "object",
    "properties": {
        "Transfer-Encoding": {
            "type": "string"
        },
        "operation-location": {
            "type": "string"
        },
        "x-envoy-upstream-service-time": {
            "type": "string"
        },
        "apim-request-id": {
            "type": "string"
        },
        "Strict-Transport-Security": {
            "type": "string"
        },
        "x-content-type-options": {
            "type": "string"
        },
        "Date": {
            "type": "string"
        },
        "Content-Length": {
            "type": "string"
        }
    }
}

これで処理の要求APIは以上です。

処理要求の結果取得までの準備

要求をしてすぐ取得できるわけじゃなく、クラウド側の処理が完了するまで待つ必要があります。
少なくとも1分程度は必ずかかるため、一度遅延処理を1分指定しておきましょう。
また合わせて、出力ができたか判定するためのフラグと要約結果を格納する変数も合わせて作成しておきましょう。

image.png

処理要求の結果取得

1分ほど待った後に、実際に処理要求の結果を取得しに行きます。

取得するまで繰り返す必要がありますので、Do Until を使い、TextAnalyze が true になるまで繰り返すように設定します。

image.png

処理要求結果取得のHTTPコネクタ

結果取得のAPI仕様はこちらに書いてあります。
Text Analytics API (v3.2-preview.1)

API の仕様に合わせて作成したHTTPコネクタはこのようになります。

image.png

URIに指定している、operation-location は、ヘッダーのJSON解析のアクションを使って指定しています。

取得結果のJSON解析

取得結果はJSONで返ってきますので、JSON解析で他のアクションでも使用できるようにします。

image.png

JSONのスキーマ情報書いときますねー\( 'ω')/

{
    "type": "object",
    "properties": {
        "jobId": {
            "type": "string"
        },
        "lastUpdateDateTime": {
            "type": "string"
        },
        "createdDateTime": {
            "type": "string"
        },
        "expirationDateTime": {
            "type": "string"
        },
        "status": {
            "type": "string"
        },
        "errors": {
            "type": "array"
        },
        "displayName": {
            "type": "string"
        },
        "tasks": {
            "type": "object",
            "properties": {
                "completed": {
                    "type": "integer"
                },
                "failed": {
                    "type": "integer"
                },
                "inProgress": {
                    "type": "integer"
                },
                "total": {
                    "type": "integer"
                },
                "extractiveSummarizationTasks": {
                    "type": "array",
                    "items": {
                        "type": "object",
                        "properties": {
                            "lastUpdateDateTime": {
                                "type": "string"
                            },
                            "taskName": {
                                "type": "string"
                            },
                            "state": {
                                "type": "string"
                            },
                            "results": {
                                "type": "object",
                                "properties": {
                                    "documents": {
                                        "type": "array",
                                        "items": {
                                            "type": "object",
                                            "properties": {
                                                "id": {
                                                    "type": "string"
                                                },
                                                "sentences": {
                                                    "type": "array",
                                                    "items": {
                                                        "type": "object",
                                                        "properties": {
                                                            "text": {
                                                                "type": "string"
                                                            },
                                                            "rankScore": {
                                                                "type": "number"
                                                            },
                                                            "offset": {
                                                                "type": "integer"
                                                            },
                                                            "length": {
                                                                "type": "integer"
                                                            }
                                                        }
                                                    }
                                                },
                                                "warnings": {
                                                    "type": "array"
                                                }
                                            }
                                        }
                                    },
                                    "errors": {
                                        "type": "array"
                                    },
                                    "modelVersion": {
                                        "type": "string"
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}

処理結果の判定

処理結果を取得した際に、処理が完了したかどうかは、Statusに記載されています。
なので、条件コネクタを使って、Statusが succeeded かどうかを判定し、処理を分岐します。

image.png

まだ実行中(runnning)だった場合

待ち時間を1分設定します。
これで、1分経過した後にループ処理で処理結果の取得が再度行われます。

処理が完了(suceeded)した場合

TextAnalyze を true に設定し、ループを抜けるようにします。

後続で、要約結果を文字列化します。

要約結果(配列データ)を文字列化

要約結果は、以下のように行単位で配列化されており、それぞれにテキストとスコアなどが出力されます。

image.png

Power Apps に返す際はテキスト結果のみを文字列で渡してあげたいので、Apply to Each と 文字列変数に追加のアクションを使って生成します。

image.png

値には、JSON解析で取得したTextと以下の式を入れて改行コードを追加しています。

decodeUriComponent('%0D%0A')

これで、テキストの要約は完了です。
あとは、Power Apps のトリガーと応答を作るだけです。

Power Apps のトリガー

image.png

Power Apps への応答

image.png

これで Power Apps への連携ができるようになります。

Power Apps の作成

といっても、Power Apps 側は特に込み入ったことはしていないのでざっくりと書きます。

image.png

要約開始のボタンには以下の式を入れています。

Set(flowrtn,<フロー名>.Run(TextInput1.Text,Slider1.Value))
  • 引数1が要約対象のテキストなので、テキスト入力のオブジェクトを指定
  • 引数2が要約行数なので、スライダーの値を指定

要約後のテキストが表示されるラベルには以下の式を入れています。

flowrtn.summarize

これで Power Apps 側は完了です。

8
5
1

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
8
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?