はじめに
Formsの設問に回答すると、回答内容がPlannerにタスク登録されるフローをPower Automateで作ってみました。
(以下タスク登録フローと呼びます。)
- Formsでタスク名、期日など作成したいタスクに関する質問に回答する
- Power Automate内で指定したユーザ宛に、Formsの回答を基にタスクを作成する
図にすると下のようなイメージです。
本記事では、タスク登録フローの作り方をご紹介します。
なぜタスク登録フローを作成したか
Plannerでチームのタスクを管理していると、チームメンバ全員が同じ内容のタスクに個別に完了報告できるようにしたい場面があるかと思います。
例えば、「XX日までに○○のアンケートに回答する」といったタスクが発生した場合などです。
1つのタスクに複数人の担当者を割り当ててしまうと、1人が完了報告した時点でPlanner上のタスクが完了ステータスになります。
一人ひとりのステータスを管理するには人数分のタスク作成が必要になり、対象メンバが多いと少し手間です。
1回の登録で全員分のタスクを作成できれば良いのにと思い、タスク登録フローを作成しました。
作成したタスク登録フロー
作成タスク管理フローは下図のような作りになっています。
詳細を開いたところ
以降では上図のタスク管理フローの作成手順を順を追ってご説明いたします。
登録フロー作成手順
Step 0. Formsでタスク登録用フォームを作成
Power Automateによるフロー作成の前に、以下項目の回答フォームを作成します。
- タスク名
- バケット名
- 開始日
- 期限
- メモ
それぞれの項目が下図のようにPlannerのタスクの各項目と対応しています。
Forms側の準備が終わったら、事前準備は完了です。
いよいよタスク登録フローを作成していきましょう!
Step 1. Power Automateで土台となるテンプレートを選択
Power Automateにはテンプレートが豊富に用意されています。
今回はやりたいことに近いテンプレートを選んで、カスタマイズしていくやり方を取りました。
下記手順でテンプレート「Microsoft Forms から Planner でタスクを作成し、Teams でメッセージを投稿する」を選択します。
- Microsoft 365にログインし、画面左上のアプリ起動ツールからPower Automateを選択
- メニューから「テンプレート」を選択
- 「Microsoft Forms から Planner でタスクを作成し、Teams でメッセージを投稿する」を選択
選択したテンプレートは最初は下図のような状態です。
以降のStepでは、タスク登録フローでやりたいことに合わせて下図のフローをカスタマイズしていきます。
Step 1-2. 不要なアクションの削除
土台として選択したテンプレート内のアクションのうち、今回のフローで使わない下記2つを削除しておきます。
- Create a task
- Post message in a chat or channel
Step 2. フォームの回答の取得処理
Power Automanteの下記2アクションに先に作成しておいたFormsの回答フォームのフォームIDを設定します。
- When a new response is submitted
- Get response details
ここまでで、タスク作成用フォームの回答が送信されたときに回答を取得します。
Step 3. バケットID取得処理の追加
Plannerの指定のバケットにタスクを作成するためには、バケットIDを指定する必要があります。
バケットIDを指定する処理は基にしたテンプレートにはないので、追加していきます。
投稿先のプランにバケットが1つしかない場合はフロー内でバケットIDを直接指定すれば良いかと思います。
が、今回のタスク登録フローでは複数のバケットからForms回答時に投稿先を選択する想定となっているため、バケット名とバケットIDを何らかの形で紐づける必要があります。
今回は、以下の手順でバケットIDを取得しています。
- 投稿先のプランのバケット名、バケットIDをまとめて取得
- 取得したバケット名とFormsで回答したバケット名を比較
- 一致したら対応するバケットIDを取得
Step 3-1. 投稿先のプランのバケット名、バケットIDをまとめて取得
+マークを押下し、「アクションの追加」を選択します。
「コネクタ」から「Planner」を選択します。
「バケットを一覧表示する」を選択し、グループIDとプランIDを指定します。
これで投稿先のプランのバケット名、バケットIDをまとめて取得できるようになりました。
Step 3-2. 取得したバケット名とFormsで回答したバケット名を比較
Step 3-1. にてバケット名をまとめて取得しました。
今度は、目的のバケット名を見つけ、バケットIDを取得する処理を追加します。
前準備として、取得したバケットIDを格納するための変数を用意しておきます。
変数の各項目を設定します。
名前:任意(ここではbucket_idとしています)
種類:文字列
値:空
変数の初期化が終わったら、いよいよ処理本体です。
3-1. で取得したバケットIDと、Formsの回答から取得したバケットIDをループで比較して、一致したらバケットIDを変数に格納します。
コントロールの「Apply to each」を選択します。1
左辺or右辺:バケットを一覧表示するで取得した「値 名前」
左辺or右辺:Formsの回答で取得した「バケット名」
※左右はどちらでも良いです。
条件:次の値に等しい
Step 3-3. 一致したら対応するバケットIDを取得
条件に一致した場合の処理を追加します。
「文字列変数に追加」を選択し、各項目を設定します。
名前:先ほど初期化した変数名
値:「バケットを一覧表示する」で取得した「値ID」
これでタスク追加対象のバケットのバケットIDが取得できました。
タスク割り当て対象の担当者のユーザIDを配列に格納
ここからはタスクを割り当てたい担当者のユーザIDを配列に格納していきます。
将来的な保守性を考えるとユーザIDのリストは外出しした方がスマートな気もしますが、今回はフロー内に直接記載してしまいます。
「変数を初期化する」を追加し、各項目を設定します。
今回は選択したアクションの種類が判らなくならないようにアクション名を初期値のまま使用しています。
実際にフローを組む時は自分が後で見て判りやすい名前に変更した方が良いかもしれません。
私の場合「ユーザIDの初期化(○○さん)」などの名前に変更しています。
名前:任意(ここではuser_id_1としています)
種類:文字列
値:対象ユーザのメールアドレス
Step 4. 割り当て対象の担当者のユーザIDを配列に格納する処理の追加
ユーザIDの初期化が終わったら、配列変数を初期化します。
「変数を初期化する」を追加し、各項目を設定します。
名前:任意(ここではuser_id_listとしています)
種類:アレイ
値:空2
Step 5. タスク作成処理
いよいよタスク作成処理です。
だいぶ長文になってしまいましたが、今しばらくおつきあいください。
1ユーザID毎に1タスクを作成したいので、繰り返し処理を選択します。
コントロールの「Apply to each」を選択し、以下のように項目を設定します。
以前の手順から出力を選択:Step 4.で作成したユーザIDの配列(ここではuser_id_list)
アクションの追加:タスクの作成(プレビュー)
タスクの作成(プレビュー)には沢山の設定項目がありますが、今回のフローでは設定項目は以下だけです。
グループID:対象のグループID
プランID:対象のプランID
タイトル:Formsの回答項目のタスク名
バケットID:Step 3-3. で取得したバケットID
開始日時:Formsの回答項目の開始日
期限日時:Formsの回答項目の期限
割り当て済みユーザーID:現在のアイテム
Step 6. メモの更新処理
「タスクの作成(プレビュー)」アクションにはメモ項目がないため、作成済のタスクを更新する形でメモを追記します。
対象のタスクを特定するためにはタスクIDが必要です。
今回は以下の手順でタスクIDを取得し、メモの更新処理を実施しています。
- 対象のプランIDに紐づくタスクをすべて取得
- 指定したタスク名と同じタスク名を持つタスクのタスクIDを取得
- 取得したタスクIDのタスクのメモを更新
Step 6-1. 対象のプランIDに紐づくタスクをすべて取得
「タスクを一覧表示します」を追加し、下記のように項目設定します。
グループID:対象のグループID
プランID:対象のプランID
「変数を初期化する」を追加し、下記のように項目設定します。
名前:任意(ここではtask_id_listとしています)
種類:アレイ
値:空
Step 6-2. 指定したタスク名と同じタスク名を持つタスクのタスクIDを取得
「Apply to each」を追加後「以前の手順から出力を選択」に「タスクを一覧表示します」の値を設定します。
「Apply to each」内に「条件」を追加し、以下のように値を設定します。
左辺or右辺:「タスクを一覧表示します」で取得した「値 タイトル」
左辺or右辺:Formsの回答で取得した「タスク名」
※左右はどちらでも良いです。
条件:次の値に等しい
「はいの場合」に「配列変数に追加」を追加し、以下のように値を設定します。
名前:Step 6-1で作成した変数名(ここではtask_id_list)
値:「タスクを一覧表示します」で取得した「値 ID」
Step 6-3. 取得したタスクIDのタスクのメモを更新
「Apply to each」を追加し「以前の手順から出力を選択」でStep 6-1で作成した変数(ここではtask_id_list)を選択します。
「タスクの詳細の更新」を追加し、以下のように値を設定します。
タスクID:今回追加した「Apply to each」の「現在のアイテム」
説明:Formsで回答した「メモ」
お疲れ様です!
以上で設定は完了です。
次はいよいよテスト実行です。
実行してみる
しばらくすると対象のチームにタスクが作成されています。
お疲れ様です!
タスク作成フロー作成は以上で終了です。
長々お付き合いいただきありがとうございました。
おわりに
Power Automateで少し複雑なフローを組んでみたのは今回が初めてだったのですが、何がやりたいかを整理してアクションを組み合わせていけばやりたいことが実現できるので、パズル感覚で楽しいなと思いました。
ここまでお読みくださった皆様のご参考に少しでもなったら嬉しいです。
参考URL
今回タスク登録フローを作るにあたり、下記を参考にさせていただきました。
https://blog-tips.sekenkodqx.jp/2020/09/21/power-automate-array-variable/
https://blog-tips.sekenkodqx.jp/2021/02/18/power-automate-action-creat-a-task-planner/
https://blog-tips.sekenkodqx.jp/2021/02/28/power-automate-action-list-buckets-planner/
https://docs.microsoft.com/en-us/connectors/office365groups/#list-group-members
https://docs.microsoft.com/ja-jp/connectors/planner/#list-buckets
https://eng-blog.iij.ad.jp/archives/6746
https://idea.tostring.jp/?p=4772
https://qiita.com/yamad365/items/481f82e8f0140a17d1e1
https://www.softbanktech.co.jp/special/blog/cloud_blog/2020/0067/
https://www.softbanktech.co.jp/special/blog/cloud_blog/2020/0071/