技術情報ブログ
Power Platform
2022.04.13

Power Apps:ForAll 関数で Set や UpdateContext を使いたい時

エンジニア募集しています

アアーティサンではローコードエンジニアをはじめ、クラウド開発者やコンサルタントなどを募集しています。
アーティサンの仕事内容や転職にご興味のある方はこちらもご覧ください。

こんにちは。アーティサン株式会社の小刀稱(ことね)です。

Power Apps でアプリを作成するとき、ForAll 関数の中で、変数を更新したいと思ったことはありませんか?

しかし、ForAll 関数内でSet 関数やUpdateContext 関数を使用することはできません。(2022年3月時点)

本記事では、ForAll関数SetUpdateContextを使いたいと思ったときの対応策について紹介します。
全パターンが今回紹介する方法で対応できるわけではありませんが、1つの案としてご覧ください。

Power Appsを用いてアプリを作成したことのある方に向けた内容となっております。

 

やりたいこと:ForAll 関数内で変数を更新する場面

はじめに、今回やりたいことを説明します。

以下図、左側のコレクション( = colBefore )があったとします。
本コレクションの中に「枝番を追加する」( = colAfter )というのが今回のやりたいことです。

枝番は、以下のロジックで付与します。

  • 1行前の番号 <> 番号 → 枝番 = 1

  • 1行前の番号 = 番号 → 枝番 = 1行前の枝番 + 1

番号が変わった場合は枝番を1に初期化し、番号が同じ場合は枝番を+1しています。

Power Apps-コレクション_枝番の追加
Power Apps-コレクション_枝番の追加

上記を行うためには、ForAll 関数の中で、1行前の番号を取得する必要があると考え、最初は以下のように記載しました。

Set(prevRecord, {番号: 0, 枝番: 0, 名前:""}); // 1行前のレコード
Clear(colAfter);
ForAll(colBefore,
    Collect(colAfter,
        {
            番号: ThisRecord.番号,
            枝番: If(prevRecord.番号 <> ThisRecord.番号, 1, prevRecord.枝番 + 1),
            名前: ThisRecord.名前
        }
    );
    Set(prevRecord, ThisRecord); // 1行前のレコードを更新
)

しかし、以下のエラーが発生してしまいました。

どうやら、ForAll 関数内ではSet 関数が使用できないようです。
(UpdateContext 関数も同様のエラーが発生します。)

Power Apps-ForAll 関数内での変数の更新
Power Apps-ForAll 関数内での変数の更新

 

対策:Last 関数を使用する

上記に対応するためには、Last 関数を用いて実装します。

Last 関数とは、指定したテーブルの最後のレコードを取得する関数です。
詳細は以下URLを参照してください。

Power Apps での First、FirstN、Last、および LastN 関数

以下にLast 関数を用いて修正した内容を記載します。

Clear(colAfter);
ForAll(colBefore,
    Collect(colAfter,
        {
            番号: ThisRecord.番号,
            枝番: If(Last(colAfter).番号 <> ThisRecord.番号, 1, Last(colAfter).枝番 + 1),
            名前: ThisRecord.名前
        }
    )
)

ポイントは、Last(colAfter)の部分です。

ForAll 関数内では、colBeforeのレコード数分、colAfterに1行ずつレコードを追加しています。 よって、ForAll 関数内でLast(colAfter)を指定すると、colAfterに最後に追加したレコード( = colBeforeの1行前のレコード )が取得できるということになります。 イメージを以下図にしました。
Power Apps-ForAll 関数内でのLast 関数を用いる
Power Apps-ForAll 関数内でのLast 関数を用いる

Last 関数を用いることで、無事枝番を付与することができました!

Power Apps-コレクション_枝番の追加完了
Power Apps-コレクション_枝番の追加完了

 

まとめ

本記事では、ForAll関数SetUpdateContextを使いたいと思ったときの対応策について紹介しました。

このような内容は、「知っていれば一瞬」ですが「知らなければ多くの時間が必要」となります。

当社では、今回のような実装のアイデアを多く発信していく予定ですので、是非今後ともご覧ください。
最後まで読んでいただき、ありがとうございました!

 

 

 

弊社ではPower Platform(Power AppsやPower Automateなど)を用いてお客様の業務を自動化するご支援を数多く承っております。

業務の中で、「普段手動でやっている業務を自動化できないか」というような疑問がある場合には、お気軽にアーティサン株式会社までお問い合わせください。

Power Platform(SharePoint・Power Apps・Power Automate)に関する営業活動や設計、開発などを担当:小刀稱知哉

小刀稱知哉

大分県出身(温泉大好き♥♥)、現在は東京都在住

1990年4月9日生まれ

30才にしてメーカーの技術営業からIT業界にジョブチェンジ!!!

趣味は読書

Power Platform(SharePoint・Power Apps・Power Automate)に関する営業活動や設計、開発などを担当しております!

シェアする
記事カテゴリ
最新記事
2023.03.23

Power Apps:キャンバスアプリでレスポンシブ レイアウト対応のアプリを作成する際の設計方針(2)

2023.03.03

Power Apps:キャンバスアプリでレスポンシブ レイアウト対応のアプリを作成する際の設計方針(1)

2023.02.22

今さら聞けないPower Automate:フローの種類とその違い(2)

2023.02.08

今さら聞けないPower Automate:フローの種類とその違い(1)

2023.01.25

【2023年1月更新】Power Automate 初心者 ~ 中級者 向けロードマップ

2021.06.23

【Power AutomateでExcelデータをSharePointにインポートするために考えること 第1回】4つのシーンごとに手法を比較、その最適解とは?

2
2021.07.14

【Power AutomateでExcelデータをSharePointにインポートするために考えること 第2回】フロー作成でエラー発生!

3
2021.09.03

【Power AutomateでExcelデータをSharePointにインポートするために考えること 第8回】トリガーの条件の指定方法

4
2020.10.02

世界に広がる Power Apps「モデル駆動型アプリ」のココがスゴイ!【第1回】

5
2022.02.16

SharePointのビューに擬似的なアクセス制限をかける方法(1)

--------------------------------------------------->
モデル駆動型アプリPower AppsPower PlatformSharePointExcelPower AutomateC#attributevalidationローコードAngularAccessInfoPathMatTableAngular Materialデータ構造SortByColumns関数TypeScriptHTMLEF CoreマイグレーションFramework CoreAttribute directivesO/Rマッパーazure sql databaseCase式HTTP RequestCSSxUnit.Net Core 3.1VSCode.Net Core Test ExplorerDataverse for Teamsitem関数Google MapsMarker ClustererRANK()関数Dynamics 365 SalesMicrosoft TranslatorマーカークラスタリングライブラリtailwindcssマルチテナントドロップダウンメニューBreakpointObserverメディアクエリスマホPCレスポンシブ入門初心者中級者キャンバスアプリDatePickerDropdownビューアクセス制限承認リマインドSetForAllUpdateContextロードマップ技術ItDX情報技術メッセージIDメールfirst()関数nest入れ子動的リストcollectionコレクション複数の添付ファイル承認フローformエクスポートインポートカスタマイズcomponentダイアログコンポーネントdialogTips新機能変数検索Microsoft 365グループセキュリティグループ送信元メールの送信差出人インスタントクラウドフロー自動化したクラウドフロー委任VBAエラーエクセルerror復元restorePower BI個人列ユーザー列SharePoint Onlineリスト非表示アプリ[市民開発者構築自動化したクラウド フローフローの種類インスタント クラウド フロースケジュール済みクラウド フローレスポンシブ レイアウトresponsive layout
PageTop
ページトップに戻る