5
0

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 1 year has passed since last update.

#PowerAutomate 任意の予定表アイテムのみフローを発火させる方法

Posted at

Microsoft 365 の予定表、使ってますか?

Microsoft 365(以降、M365)でスケジュール管理や会議室の予約、Teams 会議などで大活躍しますよね。まさか、M365 を利用しているのに使ってない・・・なんてコトは無いと信じたい。

そんな予定表で「自分が選んだ特定の予定のみ Power Automate のフローを発火させる」コトができたらチョッと便利になりませんかね?当方はなったんですよ。なので、アレコレ考えた結果、閃いたアイディアです。

Disclaimer

毎度おなじみ(?)の『イベントが追加、更新、または削除されたとき (V3)』(CalendarGetOnChangedItemsV3)トリガーを利用して説明します。この記事では他のイベント関連トリガーやアクションまではカバーしません。

Exchange Onlie は ExO と略す場合があります。また、予定や会議と”イベント”という単語で混乱するかもしれません。ExO の予定表では基本的に「予定のアイテム=イベント」になります。適宜、前後の文脈から脳内補完してください。API等では、個人の予定と会議招集は別モノだったりする場合もあるけども、そこが気になる方は是非調べてみてください😇

説明で利用するフロー

トリガーと「作成」アクションを 1つ置いただけの、とってもシンプルなフローです。

image.png

作成アクションに設定している関数は後ほど説明します。

任意の予定のみ発火させるアイディア

予定に付与できる”分類”を利用します。当記事では『紫の分類』の場合のみ、フローが発火するように設定します。

トリガーの条件

トリガーの右上にある三点(・・・)から[設定]をクリックします。

image.png

トリガーの表示が切り替わったら、末尾にある[トリガーの条件]に下記を設定して「完了」です。

image.png

@contains(triggerBody()?['categories'], '紫の分類')

これで、このフローが発火するのは『”紫の分類”が設定された場合のみ』になります。

予定表での利用例

利用例として、既に登録されている予定を発火させます。登録済みの予定を右クリック → [分類] → [紫の分類]を選択します。これだけで該当のフローが発火します。なお、紫の分類以外を選んだ場合はフローは発火しません。

image.png

もちろん、予定の新規作成画面で分類を設定しても問題ありません。

分類を利用すれば、他人から招待された会議招集であっても、任意の対象を選んで Power Automate のフローを発火させて自動化が実現できます。もちろん、Teams のカレンダーから分類を指定した場合も同様の動作となります。

作成アクションの関数

既にネタバレしているかな?とは思いますが、作成アクションで指定している関数は下記になります。

concat( triggerOutputs()?['body/categories'] , ',' )

予定の”分類”(categories)を concat 関数でカンマ区切りの文字列にしているだけ、です。

ExO の予定表アイテムには、複数の”分類”が指定可能です。そのため Power Automate の発火結果では分類(= categories)が配列になります。

実行結果の例

上記のフロー動作イメージはです。指定した分類以外では発火していないのですが、ソレをわかりやすくお伝えするのが非常に大変なので、皆さんも是非お手元の環境で試して実感してほしいです。

トリガーの出力結果を眺めてみる

分類が配列になっている状態は、フローの実行結果から確認できます。以下は参考例です。

{
    "headers": {
        ~割愛~
    },
    "body": {
        "ActionType": "added",
        "IsAdded": true,
        "IsUpdated": false,
        "subject": "test",
        "start": "2023-06-15T00:00:00.0000000",
        "end": "2023-06-15T00:30:00.0000000",
        "startWithTimeZone": "2023-06-15T00:00:00+00:00",
        "endWithTimeZone": "2023-06-15T00:30:00+00:00",
        "body": "",
        "isHtml": true,
        "responseType": "organizer",
        "responseTime": "0001-01-01T00:00:00+00:00",
        "id": "AAMk~~ZlFxfAAA=",
        "createdDateTime": "2023-06-15T14:29:23.8074833+00:00",
        "lastModifiedDateTime": "2023-06-15T14:29:23.8851813+00:00",
        "organizer": "naisho",
        "timeZone": "UTC",
        "iCalUId": "04000000~~3E16430B71DB17",
        "categories": [
            "紫の分類",
            "赤の分類"
        ],
        "webLink": "割愛",
        "requiredAttendees": "",
        "optionalAttendees": "",
        "resourceAttendees": "",
        "location": "",
        "importance": "normal",
        "isAllDay": false,
        "recurrence": "none",
        "reminderMinutesBeforeStart": 15,
        "isReminderOn": true,
        "showAs": "busy",
        "responseRequested": true,
        "sensitivity": "normal"
    }
}

今回のようなテクニックは上記のトリガー出力結果と、ExO 予定表アイテムの仕様をイメージして閃いたテクニックです。

補足

ExO 予定表の分類は、ユーザー自身で表記や色を変更できます。今回はデフォルト設定のまま説明しています。既に変更している方は適宜現状の設定内容にあわせた対応を実施ください。

結び

例えば「特定の予定をトリガー条件にして●●したい。ただし、全ての予定で発火されては困る」という条件の場合にはバッチリとハマるテクニックだと思います。と言うか当方自身が、その必要に迫られた、って感じですね(ネタバレ

それでは、皆さま、素晴らしい Power Platform Life を!

5
0
0

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

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?