Power AutomateとPower Appsで作る!効率的な勤怠管理アプリの実践ガイド #PowerAutomate - Qiita

はじめに

最初の投稿では、Power Automateを使って定期連絡フローを作成しました。次に、Power Appsを利用してSharePointリストに勤務時間を打刻する方法をご紹介します。今回は最新の投稿に自動的に返信できるようにすることで勤怠を管理したいと思います。

Power Automateとは

Microsoftが提供するRPA(ロボティック・プロセス・オートメーション)ツールです。Power Automate使うことで、日常的な繰り返し作業を自動化し、業務の効率化を図ることができます。例えば、メールの自動返信やデータの入力、ファイルの保存などを自動化できます。

Power Appsとは

Power Appsは、Microsoftが提供するローコード開発プラットフォームで、ユーザーが簡単にカスタムアプリを作成できるツールです。コードの知識が少なくても、ドラッグ&ドロップでアプリを構築し、データの接続や自動化を実現できます。ビジネスプロセスの効率化に役立ちます。

Power Appsで勤怠管理アプリを作成する

まず、初めに勤怠管理アプリを作成します。デザインは個人によって異なるため、今回は詳細な説明を省略します。画面を作成する際に、出勤ボタンと退勤ボタンを追加します。

スクリーンショット 2025-03-30 011141.png

ボタンを押した際に投稿に返信する

  • 出勤ボタンを押した際には「おはようございます。出社です。」
  • 退勤ボタンを押した際には「お疲れ様です。退社いたします。」

を、毎月自動的に投稿されるメッセージに対して返信できるようにしたいと思います。
毎月自動的に送信される投稿に関しては下記の記事で取り上げております。

出勤ボタン

出勤ボタンを押した際には、プルダウンで出社、在宅、客先の3つで選択したものをメッセージに含められるようにしたいと思います。

image.png

出社
「おはようございます。出社しました。」
在宅
「おはようございます。在宅勤務です。」
客先
「おはようございます。客先勤務です。」

プルダウンで選択後、出勤ボタンを押した際に毎月自動的にteamsに投稿されるスレッドに対して返信します。

Power Automateでフローの作成

勤怠管理アプリを作成するにあたり、Power Automateで3つのフローを作成しました。
作成したフローは下記の3種類です。

  • 最新スレッド取得フロー
  • 出勤メッセージフロー
  • 退勤メッセージフロー

最新スレッド取得フロー

初めに、最新スレッド取得フローを作成いたします。最新スレッド取得フローとは、Teamsの最新のスレッドを自動的に取得するフローです。

Power Automateの画面左メニューの[作成]を選択し、「インスタンスクラウドフロー」を選択します。

image.png

アクションの追加で「Teams」で検索し、「メッセージを取得します」を選択します。

image.png

選択すると、チームとチャネルを選択することができるので、下記を入力します。

  • 任意のチーム
  • 任意のチャネル

image.png

次に、アクションの追加で「json」で検索し、「データ操作」「jsonの解析」を選択します。

image.png

次に、アクションの追加で「変数」で検索し、「変数を初期化する」を選択します。

image.png

選択すると、名前、種類、値を選択することができるので、下記を入力します。

  • 名前:任意
  • 種類:任意
  • 値:

body('JSON_の解析')?['value'][0]['id']

最後に、アクションの追加で「power app」で検索し、「Power App またはフローに応答する」を選択します。

image.png

選択すると、「+出力を追加する」が表示されるのでクリックし、「テキスト」を選択します。

image.png

テキストを選択すると、入力する箇所が二つあるので、

  • 名前:messageID
  • 種類:先ほど設定した変数名(messageID)
    を設定します。

image.png

これで最新のスレッドを取得するフローの完成になります。
Power Appsでボタンを押せばいつでも呼び出せる形となっております。

出勤メッセージフロー

次に、出勤メッセージフローを作成いたします。
まず、インスタンスクラウドフローを選択し、トリガーを「Power Appsがフローを呼び出した時」を選択します。
フロー名は任意で問題ございません。

image.png

フローを選択すると、子フローの実行というものがアクションにあるので、選択します。

image.png

「子フローの実行」はソリューションに対象となるフローが入っていないと表示されません

始めに、Power Apps (V2)の設定をします。
入力の追加で3個のテキストを追加し、下記を入力します。

image.png

次に、アクションの追加で「変数」で検索し、「変数の初期化」を選択します。

image.png

変数の初期化で「名前」、「種類」、「値」を入力できる箇所があるので下記を入力します。

  • 名前:place
  • 種類:文字列
  • 値:空白

image.png

次に、アクションの追加でコントロールを選択します。

image.png

コントロールを選択後、スイッチを選択します。

image.png

スイッチを選択後、条件を「ケース1」、「ケース2」、「限定」の三種類にします。(⊕ボタンを押すことで条件を増やすことができます)
image.png

スイッチの値の選択することができるので、動的コンテンツを選びます。
選んだ後、Power Apps (V2)に「場所」があるので設定します。

image.png

出社

ケースが三種類あり、最初にケース1を選択します。
選択後、次の値と等しいのところが入力できるので「出社」と入力します。

image.png

その後、「アクションを追加」を選択し、変数の設定をクリックします。
クリック後、「名前」、「値」を下記のように入力します。

  • 名前:place
  • 値:出社

客先

次にケース2に移りたいと思います。
先ほど同様に、次の値と等しいのところが入力できるので「客先」と入力します。
入力後、アクションの追加で「変数の設定」を選択し、「名前」、「値」を下記のように入力します。

  • 名前:place
  • 値:客先

image.png

在宅

最後にケース3(限定)に移りたいと思います。
限定ではアクションの追加で「変数の設定」で、「名前」、「値」を下記のように入力します。

  • 名前:place
  • 値:在宅

image.png

出勤

子フローの実行

次に最初に作成した「最新スレッド取得フロー」を呼び出しす方法を追加します。
新しいステップで、組込みの中のフローを選択します。

image.png

フローを選択すると「子フローの実行」が表示されるので、それをクリックします。

image.png

プルダウンで一番最初に作成した、「最新スレッド取得フロー」があるのでそれを設定します。

image.png

子フローを取得し、実行することで、別のフローを呼び出すことができるようになります。

Teamsへの投稿

新しいステップで「teams」と検索し「チャネル内のメッセージで応答します」を選択します。

image.png

選択すると5個入力するところがあるので、下記を入力します。
おはようございます。後に動的コンテンツで先ほど設定した変数(place)を設定することでプルダウンで選択したものがメッセージに含まれるようになります。

  • 投稿者:任意
  • 接続先:チャネル
  • メッセージ ID:messageID
  • チーム:任意
  • チャネル:任意
  • メッセージ:

メッセージ

おはようございます@{variables('place')}です

image.png

これで出社メッセージフローは完成です。
次に今回作成した「出社メッセージフロー」とPowerappsの出社ボタンを紐づけたいと思います。

出勤ボタンと出勤フローの連携

出勤ボタンを選択し、下記の関数を入力することでPower AppsからPower Automateを呼び出しております。

出勤メッセージフロー.Run

image.png

今回は出勤メッセージフローと名付けましたが、Power Automateで設定した名前を記載しても問題ございません。

実際にボタンを押してみると下記のように、対象のスレッドに対して、ボタンを押すことで自動的にメッセージを送信することができました。

image.png

退勤

まず、インスタンスクラウドフローを選択し、トリガーを「Power Appsがフローを呼び出した時」を選択します。
フロー名は任意で問題ございません。

退勤メッセージフロー(Power Automate)

最後に退勤メッセージフローを作成します。
まず、インスタンスクラウドフローを選択し、トリガーを「Power Appsがフローを呼び出した時」を選択します。

出勤ボタン同様に、子フローの実行というものがアクションにあるので、選択します。

image.png

子フローの実行では、先ほど作成した「最新スレッド取得フロー」を選択します。

image.png

次に、「teams」で検索し「チャネル内のメッセージで応答します」を選択します。

image.png

選択すると5個入力するところがあるので、下記を入力します。

  • 投稿者:任意()
  • 接続先:チャネル
  • メッセージ ID:messageID
  • チーム:任意
  • チャネル:任意
  • メッセージ:お疲れ様です。退社いたします。

image.png

これで退勤メッセージフローは完成です。
次に今回作成した「退勤メッセージフロー」とPowerappsの退勤ボタンを紐づけたいと思います。

退勤ボタンと退勤メッセージフローの連携

最後に退勤ボタンと退勤メッセージフローを紹介させていただきます。
退勤ボタンを選択し、下記の関数を入力することでPower AppsからPower Automateを呼び出しております。今回は「退勤メッセージフロー」と名付けましたが、Power Automateで設定した名前を記載しても問題ございません。

退勤メッセージフロー.Run

image.png

今回は退勤メッセージフローと名付けましたが、Power Automateで設定した名前を記載しても問題ございません。

退勤ボタンを押してみると、実際に退勤メッセージを送信することができました。

image.png

まとめ

今回は、Power AutomateとPower Appsを組み合わせることによって、Teamsの最新のスレッドに対して返信することができるようになりました。合計4つのフローとPower Appsを連携させることで、勤怠管理アプリを作成することができました!
勤怠管理アプリは現在も実際に活用しており、毎日の勤怠を楽にすることができました。
これにて勤怠管理アプリでのQiitaの投稿は最後になります。
次は他のアプリを作成しようと考えているので、よろしくお願いします。



フラッグシティパートナーズ海外不動産投資セミナー 【DMM FX】入金

Source link