はじめに
名刺を管理するというソリューションは既に沢山あるという認識ですが、Power Platform と AI Builder を使うことで、簡単に作成 (データを保存、他システムに連携) することも可能です。
一例として、今回は、以下のようなアプリを爆速で開発する方法を紹介します。
AI Builder でプロンプトを作成
まず、AI Builder の AI プロンプトにて、以下のようなカスタムプロンプトを作成します。名刺から抜き出したい情報をベースにプロンプトを作成します。こちらは、ChatGPT と同じ要領で作成できます。場合によってはプロンプトの案自体を ChatGPT に頼んでもいいと思います。
以下のインプット情報から情報を抽出し、JSON形式にしてください。JSON形式以外の文字を返答に含めないでください。
サンプルの情報は出力されないようにしてください。
###インプット情報
名刺情報
###JSON形式
{
"surname": "姓",
"given_name": "名",
"name": "姓名",
"company": "会社名",
"department": "部署",
"position": "役職",
"phone": "電話番号",
"email": "メールアドレス"
}
この、プロンプトで情報を抽出して JSON 形式にする方法はかなり強力で、色々と応用が効きます。市民開発者の方にとって、JSON はなじみがない、ハードルが高いというケースもあると思いますが、こちらをクリアすれば、あとは、後述する Power Automate で解析してデータ連係が可能になるので、是非チャレンジしていただけたらと思っています。
Dataverse のテーブルを作成
名刺情報を保存する Dataverse のテーブルを作成します。
こちらは、Copilot の機能を使い、自然言語ベースでサクッと作成します。
※Department の列を後で追加しました。
Power Apps でアプリを作成
Power Apps でサクッとアプリを作ります。
まず、作成した GPT プロンプトをアプリに追加します。
以下のようにコントロールを配置し(正直、デザインはそんなにこだわっていないです。好きなデザインで作成ください)、テキスト入力コントロールの [Value]
のプロパティを以下のようにします。こちらの式では、OCR で読み取った内容を改行しております。
Concat(TextRecognizer1.Results,Text," "&Char((10)&" "))
ボタンコントロールの[OnSelect]
の処理を以下のようにします。作成した GPT プロンプトの結果を変数に格納します。
Set(
gblBusinessCardJsonData,名刺情報抽出.Predict(TextInputCanvas1.Value).Text
);
Navigate(Screen2)
Screen を追加し、ボタンから Power Automate フローを呼び出すようにします。
名刺情報保存フロー.Run(gblBusinessCardJsonData);
Notify("名刺情報を保存しました",NotificationType.Success);
Power Automate でデータを保存
Power Automate 側のフローは以下のようにシンプルです。
JSON の解析は、Power Apps 側で生成した JSON をコピーしてサンプルとして使用するだけです。そのため、スキーマについて細かく理解していなくても大丈夫と思います。そうすることで、以下のように作成した Dataverse の各テーブルにノーコードで紐付けるだけです。
これだけで、名刺を OCR で読み取り (モバイルの場合その場で写真を撮り)、読み取った情報を Dataverse に保存するアプリの完成です。
まとめ
今回は、Power Platform と AI Builder のプロンプトで名刺管理するアプリを爆速で開発する方法を紹介しました。もちろん、画像データを合わせて保存もできますし、JSON に変換しているため、他システムに連携することも出来ますし、名刺情報だけでなく、取引先情報を登録したり、名刺と合わせて打ち合わせの情報を登録したりすることも簡単に出来ます。
このように、AI Builder の OCR の機能と AI プロンプトを組み合わせることで、簡単に画像や pdf ファイル情報を読み取り、他システムにデータ連係することがノーコード、ローコードベースで可能になり、市民開発者含め、多くの方にとって、可能性が大きく広がると思います。 色々なシナリオに応用が利くため、是非参考にしていただければと思います。