Power AppsPower Apps 初心者講座関数関数解説

【Power Apps】条件式関数/演算子まとめ

Power Apps

Power Appsでは、条件式を扱うための関数や演算子が豊富に用意されており、さまざまな条件式やBoolean値で利用される基本的な要素なのでよく理解しておく必要があります。
これらの関数と関連する演算子(=<>&&||!など)について、具体的な使用例とともに解説します。

関数説明・構文

比較演算子

値を比較するために使用する演算子です。

演算子説明
=等しい値 = 10
<>等しくない値 <> 10
in含む"a" in 値
<より小さい値 < 10
>より大きい値 > 10
<=以下値 <= 10
>=以上値 >= 10
Power Apps の演算子と識別子 - Power Platform | Microsoft Learn

in演算子は今回紹介しませんので、以下の記事をご覧ください。

論理演算子

複数の条件を組み合わせるために使用する演算子です。
これらは関数でも同じことができるので、可読性に応じて使い分けましょう。

演算子説明
&&かつ (And)条件1 && 条件2
And(条件1, 条件2)
||または (Or)条件1 || 条件2
Or(条件1, 条件2)
!否定 (Not)!条件
Not(条件)
And、Or、および Not 関数 - Power Platform | Microsoft Learn

If関数

条件式を最も使用するIf関数も紹介しておきます。

条件が true の場合は 1 つの値を返し、false の場合は別の値を返します。

公式より引用
If(条件式, 真の場合の値 [,偽の場合の値] )

基本的な使い方

If関数での条件分岐

If関数を使用して、条件に応じて異なる値を返すことができます。

// 数値が10より大きい場合は「大きい」、それ以外は「小さい」と表示
If(
    Value > 10,
    "大きい",
    "小さい"
)

複数条件の組み合わせ

論理演算子を使用して、複数の条件を組み合わせることができます。
よくあるAからBの範囲にあるかどうかは以下のような数式で判断できます。

// 数値が10より大きく、20より小さい場合は「範囲内」、それ以外は「範囲外」と表示
If(
    Value > 10 && Value < 20,
    "範囲内",
    "範囲外"
)

日付範囲の判定も可能です。

Notの使い方

ブール値の値をtrueからfalseに、falseからtrueにすることができます。

以下4例はどれも同じ出力(true)をしますので、関数の制限などに応じて使い分けてください。

true <> false
true = !false
Not(true = false)
!(true = false)

実践的な活用例

コントロールの表示/非表示制御

Visibleプロパティに条件式を設定して、コントロールの表示/非表示を制御できます。

// Slider1の値が50以上の場合のみLabelを表示
Label.Visible = Slider1.Value >= 50

ちなみにこの書き方でも問題ないですが、数式が長くなるだけなのでIfを使用する必要はないです。

条件式だけでブール値が出力されるので、Ifでの条件分岐は不要

Filter関数との組み合わせ

Filter関数の条件式として使用することで、データの絞り込みができます。
第二引数以降の条件は増やすほどAnd条件でフィルターされていきますので、Or条件が必要な場合はOr関数または||を使用しましょう。

//Filter関数をOr条件フィルター
Filter(
    SampleList,
    Or(
        容量.Value = First(ComboboxCanvas1_1.SelectedItems).Value,
        容量.Value = Last(ComboboxCanvas1_1.SelectedItems).Value
    )
)

複雑なフィルターになってくるとFilter関数の外側にIfを使用して条件分岐したくなりますが、可読性や保守性が著しく低下しますのでやめてください🙇‍♂️

Power Apps ギャラリーのフィルター はAND、ORを使おう(IF文ネストは増えると大変) | Power Apps Tips ログ

入力値の検証

Button.OnSelect等で入力値のバリデーションチェックができます。

If(
    // テキスト入力が空でないことをチェック
    !IsBlank(TextInput1.Text) &&
    // 数値が0より大きいことをチェック
    Value1.Value > 0,
    // 条件を満たす場合の処理
    Collect(テーブル, {列1: TextInput1.Text, 列2: Value1.Value}),
    // 条件を満たさない場合の処理
    Notify("入力値を確認してください", NotificationType.Error)
)

こちらも条件が増えるほど可読性や保守性が低下するので、他の実装方法や簡単な実装方法も考える必要があります。

おわりに

Power Appsはローコードツールというのは名ばかりで特に条件式はゴリゴリに数式を考える必要があり、複雑なロジックをそのままゴリゴリに書いてしまうと可読性やパフォーマンスが低下してしまいます。

そうならないためにもあらかじめ条件を整理したり、他の実装方法を検討したりなどの工夫が必要になります。

コメント

タイトルとURLをコピーしました