(2020/01/19 更新)
手順 14 で、「SharePoint の項目の更新は、すべての列に何かしら値を入れて更新する必要がある」と記載していましたが、正しくは「"必須入力の列" は何かしら値を入れて更新する必要がある」でした。お詫びして訂正します。
#はじめに
本記事は、以下の記事で紹介した日用品の購入管理アプリの作成手順のうち、Power Automate の部分の作成手順を Power Automate 初学者向けに書き起こしたものです。
元記事:Power Apps で日用品の購入管理アプリを作る
なお、上記の記事では Power Automate でメール送信まで行っていますが、本記事は Power Automate の最低限の使い方を知ることを目的としているため、最低限の処理(残日数の減算処理)のみを紹介します。
#やりたいこと
SharePoint にある日用品-品目リストの残日数の値を 1 減算する、という処理を、毎日定期実行させます。
これを Power Automate で行う場合、例えば以下のようなアルゴリズムになるかと思います。
1. 減算するための変数を初期化する
2. SharePoint の日用品-品目リストの全データを取得する
--- 以下、品目の数だけ 3. を繰り返す ---
3. 残日数が 0 より大きいか確認する
0 より大きい場合:
3-1. 残日数の値を 1. の変数に格納する
3-2. 変数の値を 1 減算する
3-3. 変数を用いて SharePoint のデータを更新する
0 以下の場合:
何もしない
ということで、早速作成してみたいと思います。
#作成手順
-
定期実行させるフローを作成します。
定期実行は、Power Automate の画面左側の「作成」から、「スケジュールされたフロー」を選択します。
-
初期設定画面。
今から作成するフローに名前を付けます。
開始時間はお好きな時間に設定してください。
繰り返し間隔を1日にし、「作成」をクリック。
-
こんな画面になります。
ここから処理を追加していきます。
まずは「新しいステップ」を選択して、処理で利用する変数の初期化を行うアクションを追加します。
-
適当な変数名を付け、種類を「Float」にします。
※SharePoint 側の数値列の型が Float になっているようなので、型を合わせます。
今回は変数の演算を行う前に必ず代入処理を行うため、値(初期値)は空欄のままでも結構です。
-
続いて、SharePoint からデータを取得するアクションを追加します。
検索窓に「SharePoint」と入力し、「複数の項目の取得」を選択します。
-
続いて、取得したデータの残日数が0より大きいかを判断するために条件分岐を挿入します。ちょうど「条件」が表示されているので、それを選択。なければ検索してください。
なお、本来ここからは繰り返し処理となりますが、以後の手順で自動的に繰り返し処理に切り替わりますのでご安心を。
-
お、自動的に繰り返し処理(Apply to each)で囲われました。残日数の項目は繰り返し取得するものと Automate が勝手に判断したためです。
-
続いて、"はい" の場合に減算処理を行います。まずは処理のために変数に値を格納します。これまでと同じ要領で「変数の設定」アクションを追加し、以下のように前述で初期化した変数に残日数の値を設定します。
-
次に、先ほどの変数の値を減算します。同じ要領で「変数の値を減らす」アクションを追加し、以下のように設定します。1 減算するので、値を 1 とします。
-
最後に減算した変数の値を SharePoint に格納します。同じ要領で「項目の更新」アクションを追加します。
更新したい列だけを更新(残日数の列に先ほどの変数を入れる)したいところですが、必須入力項目は何かしら設定する必要があります。そこで、必須入力列には先ほど SharePoint から取得した値をそのまま格納することで、値を変えずに更新するという方法をとります。
これで、フローは完成です。とりあえず保存しておきましょう。 -
完成したら、フローに問題がないかチェックします。
画面右上の「フロー チェッカー」をクリックし、エラーや警告が表示されないことを確認します。
-
各アクションの実行状況が確認できます。
エラーになっていないか確認しましょう(緑色のチェックが表示されていれば OK)。
問題なければ、これで完成です。 -
フローの実行状況は、該当フローの詳細画面で確認することができます。
この時点ではまだテスト実行しかしていないため、実際に設定した時刻に動作するかどうかを後ほどチェックしておきましょう。
#おわりに
この程度のフローであれば、関数の記述すらないため、慣れてしまえば誰でも簡単に作成できるのではないかと思います。
「コツを掴んだぜ!」という方は、同じ要領で元記事にあるメール送信処理も加えてみてください^^
メール送信方法についてはテンプレートや数多くの記事が出ていますが、参考に直近の記事であるたく丸さん(@github129)の以下の記事をご紹介しておきますので、ご参考にされてください!
【#PowerAutomate】Excel から ブログの記事を自動生成してメールで送る方法
ご参考になれば幸いです。