キャンバスアプリからChatGPT(OpenAIのAPI)を呼び出してみたので、その結果をメモ。
今回使用するAPI
今回使用するAPIは「Create chat completion」。
公式はこちら
![]()
Just a moment...
API Keyの取得
APIの実行にはAPIKeyが必要なので、OpenAIのサイトから取得する。
Power Automateの作成
今回はカスタムコネクタを使用せずに、Power Automate経由でChatGPTを呼んでみる。
Power AutomateのトリガーはV2を選んで、
data:image/s3,"s3://crabby-images/0e702/0e702bfc49b6f7fc6d2313cf7eb88f953c5a74c0" alt=""
data:image/s3,"s3://crabby-images/0e702/0e702bfc49b6f7fc6d2313cf7eb88f953c5a74c0" alt=""
APIのReference通り、こんな感じでHTTPリクエストを呼び出す
data:image/s3,"s3://crabby-images/870b8/870b8a20e5a8e643fa8612789f671804b51e5c35" alt=""
data:image/s3,"s3://crabby-images/870b8/870b8a20e5a8e643fa8612789f671804b51e5c35" alt=""
実際に呼び出してみると、
data:image/s3,"s3://crabby-images/3fe1a/3fe1a6d0e0ba8d7aadc241bde28bbae93c0aa7d5" alt=""
data:image/s3,"s3://crabby-images/3fe1a/3fe1a6d0e0ba8d7aadc241bde28bbae93c0aa7d5" alt=""
こんな感じで返答が返ってくるので、
data:image/s3,"s3://crabby-images/5132c/5132c07c5c8eabfcbcf39a66d4bf054b411dee92" alt=""
data:image/s3,"s3://crabby-images/5132c/5132c07c5c8eabfcbcf39a66d4bf054b411dee92" alt=""
JSONの解析に本文を、
data:image/s3,"s3://crabby-images/8c3a3/8c3a37bf3462b9385966070e9748c5d075015a91" alt=""
data:image/s3,"s3://crabby-images/8c3a3/8c3a37bf3462b9385966070e9748c5d075015a91" alt=""
スキーマにさっきの戻り値を入れてあげる。
data:image/s3,"s3://crabby-images/65276/652768b14bad6fe1659be6dcef929311e316001a" alt=""
data:image/s3,"s3://crabby-images/65276/652768b14bad6fe1659be6dcef929311e316001a" alt=""
解析したJSONの中身のGPTからのメッセージをApps側に返してあげる。
※function Callingを使用していないので、choicesの最初のレコードがそのまま返答になる。
※function Callingを使用していないので、choicesの最初のレコードがそのまま返答になる。
first(body('JSON_の解析')?['choices'])?['message']?['content']
これでPower Automateは作成完了!
Power Appsからの呼び出し
作成したフローをAppsから呼び出してみる。
フローを追加して、
data:image/s3,"s3://crabby-images/805dc/805dc251e166129b417d72ea5aad5b2ac9d7ae31" alt=""
data:image/s3,"s3://crabby-images/805dc/805dc251e166129b417d72ea5aad5b2ac9d7ae31" alt=""
フローからの戻り値を変数に入れて、
data:image/s3,"s3://crabby-images/b7d0e/b7d0e59405a3f59f9ba11d14335bf0804d6cb064" alt=""
data:image/s3,"s3://crabby-images/b7d0e/b7d0e59405a3f59f9ba11d14335bf0804d6cb064" alt=""
ラベルに表示する。
data:image/s3,"s3://crabby-images/17820/17820145c506b2bdb4f7f08ee7596fbae31cde68" alt=""
data:image/s3,"s3://crabby-images/17820/17820145c506b2bdb4f7f08ee7596fbae31cde68" alt=""
動かしてみるとこんな感じ!
data:image/s3,"s3://crabby-images/63492/63492175b5d79031404bf2e196005908ac62e351" alt=""
data:image/s3,"s3://crabby-images/63492/63492175b5d79031404bf2e196005908ac62e351" alt=""
今回はOpenAIを呼び出したけど、Azure OpenAIも同じように呼び出すことは可能。
次回は画像生成を呼び出してみる。
コメント