タイトル通りのフローをPowerAutomateで作ったのでメモです。
久々に作ってみたら結構色々忘れてたので備忘録を兼ねてます。
中身は下記です。
- フロー全体像・入力と出力
- スケジュールでPAC起動する
- 「フォルダの一覧」でフォルダ内ファイルの情報を取得する
- 今日の日付を”yyyy/MM/dd”というフォーマットに変換する
- ForEachをフォルダ内それぞれのファイルに適用する
- 各ファイルの最終更新日のフォーマットを変換する
- 今日更新されたものを条件分岐で判断する
- ファイルのリンク付きの投稿をTeamsの所定のスレッドに返信する
1. フロー全体像・入力と出力
下記画像参照。
アクションの名称変えてるのでぱっと見どこで何してるかわかるかなと思います。
ちなみに使ってるアクションの元の名前は下記です:
- Sharepoint「フォルダーの一覧」
- Date Time「現在の時刻」
- Date Time「タイムゾーンの変換」
- Control「それぞれに適用する」 (For each)
- Control「条件」
- Microsoft Teams「チャネル内のメッセージで応答します」
1-1.入力
入力は下記フォルダ内の2ファイルとします。
これらのファイルの最終更新日が今日だったらフローが色々やる感じです。
もっとファイルがあっても機能します。
1-2.出力
出力は下記のように、所定のスレッドに返信のかたちでファイル名とリンクが投稿されるものです。リンクはハイパーリンクになっており、クリックするとそのファイルが開きます。
目立たせたいならメンション付けるといいと思います。
あと更新したファイルが多いとスレッド追うの大変そうなので、その場合は別のかたちの出力にするといいんじゃないかと思います。
2. スケジュールでPAC起動する
特にひねりないですが下記です。
平日のみの起動を想定しているのでFrequencyは「週」にして月~金を選択してます。
3. 「フォルダの一覧」でフォルダ内ファイルの情報を取得する
これ名前がわかりにくいんですが、「所定のSharepoint Folder内のファイル(フォルダ)の属性が取得できる」アクションです。
下記の設定では、「自分用Teams」というSharepoint(Teams)の中のGeneral(一般)の中の"00_Trial"というフォルダを指定してます。
フォルダの指定は「ファイル識別子」のスペースの右側のフォルダアイコンをクリックして選択するようにすると入力ミスが避けられると思います。
なお当アクションで取得できる動的コンテンツ(保存されてるファイルの属性)は下記です。
注意点として、"Name"と"DisplayName"が別物なので注意です。
現在そのフォルダに表示されているファイル名が"DisplayName"で、一番最初にそのファイルを作ったときの名前が"Name"です。
例えば"Sample.xlsx"というExcelを新規に作って保存して、その後なんらかの理由で"hoge.xlsx"に変更すると、"Name"は"Sample.xlsx", "DisplayName"は"hoge.xlsx"になります。
4. 今日の日付を”yyyy/MM/dd”というフォーマットに変換する
これはDate Time「現在の時刻」「タイムゾーンの変換」を併せて使います。
まず「現在の時刻」は何も編集できないので中身が下記です。
一方で、フローの後半で「ファイルの最終更新日」と「本日の日付」を比較したいので、日付の情報のみにしてフォーマットを合わせる必要があります。
しかし「現在の時刻」のデフォルトの出力(動的コンテンツ)は時間を含むので、それを排除した表示形式に変換する必要があります。
そこで使うのが「タイムゾーンの変換」です。
まず1つ前の「現在の時刻」は初期設定では「標準時」の時刻が出るので、それを"Destination Time Zone"の欄で日本の時刻に直します。
その後"Time Unit"で希望のフォーマットに変更します。
表示されているフォーマットだと例えば今日なら'2024/10/06'と表示される形式です。
ただyyyy/MM/ddの形式は標準の選択肢にはない形式なので、「カスタム値の入力」を選択してから"yyyy/MM/dd"と直接打ちます
なお表示形式はフロー後半で適切に比較できさえすればなんでもいいです。
今回はできるだけシンプルな表現で、かつ「カスタム値の入力」の例をあげる意味でこれにしてます。
5. ForEachをフォルダ内それぞれのファイルに適用する
For Eachの中身は下記ですが、これ別に何もしなくても、「フォルダの一覧」で生成される動的コンテンツを使った何かのアクションを作ると自動的に生成されるので特に細かくは気にしなくていいと思います。
始めてやると「え何これ」びっくりするかもですが、「フォルダの一覧」では複数のファイルの動的コンテンツが生成される関係で、自然とそれに対応するようにPowerAutomateが調整してくれるんで素直に頼っちゃいましょう。
6. 各ファイルの最終更新日のフォーマットを変換する
これはやってることは前述の段落4番と同じですが、入力として「フォルダの一覧」で生成された各ファイルの更新日の動的コンテンツ"LastModified"を使ってる点が違うだけです。
7. 今日更新されたものを条件分岐で判断する
これはControl 「条件」を使ったもので、下記の判別式を使ってます。
条件式の右辺と左辺が紛らわしいですが、左(黄色ハイライト)が段落6で生成したSharepoint内の各フォルダの最終更新日で、右(緑ハイライト)が段落4で生成した今日の日付です。
YES(合致)するなら所定のスレッドへの返信、NOならば何も起こらないようになります。
8. ファイルのリンク付きの投稿をTeamsの所定のスレッドに返信する
ここはちょっといくつかポイントがあるので分けて説明します。
各設定詳細は下記です。
8-1. 所定のスレッドに返信する
スレッドに返信するにはスレッドのID(Message ID)を取得する必要がありますが、これは下記手順で確認できます。
1) 返信したいスレッドの右上の「・・・」からリンクをコピーを選択する
2) メモ帳などに適当にコピペし、"parentMessageId="以降の数字を確認する。
リンクをペーストしてみるとすごいわけわからないごちゃごちゃした文章出ると思いますが、ざっくりした構造は下記です。parentMessageId以外にも色々あるのがわかると思います。
で、PACでMessageIDの欄に確認したID貼ればOKです。
8-2. Teams投稿にハイパーリンクを埋め込む
これは「ファイルの一覧」で出る"Path"という動的コンテンツを使います。
ただそれをそのままメッセージに入力すると、テキストとして表示されるだけでハイパーリンクになりません。なのでハイパーリンク化の設定が必要になります。
これは説明用のテキストを別途を加えて説明します。
-
HTML編集モードにしたら、"Path"の動的コンテンツの前後にそれぞれ黄色ハイライトの文章を加える。
実際"Path"だけをhrefの最初のタグにいれるのも操作としてはできるのですが機能しません。なのでhttps:...から始まる部分を付けたうえでPathを加える必要があります。
これで序盤にあげた出力のようにハイパーリンクが付いた投稿になります
まとめ
今回はSharepoint内の所定のファイルが更新された際、最終更新日が今日だった場合にそれを自動的にリンク付きで連絡するためのフローの解説してみました。
どこかのどなたかのお役に立てば幸いです。