Power AutomateのスイッチにSharePointリストの選択肢列を使用したいとき、少し手間取ったのでメモ。
やりたいこと
こんな感じで選択肢列があるSharePointリストをPower Automateのスイッチで使いたいときのお話し。
data:image/s3,"s3://crabby-images/f687b/f687bfd7f5200fd4f2a01a90464505ca7b0c4b6a" alt=""
列名をそのまま選ぶとエラーになる
こんな感じでスイッチの「オン」に選択肢列の名前を選ぶと、
data:image/s3,"s3://crabby-images/65681/656816befd334dcde2b5b0d174354f6895d2138b" alt=""
data:image/s3,"s3://crabby-images/65681/656816befd334dcde2b5b0d174354f6895d2138b" alt=""
data:image/s3,"s3://crabby-images/01d44/01d4458ff7b03afade038d345dfde783a3c8f8cd" alt=""
フローはエラーを発生させる。
data:image/s3,"s3://crabby-images/baf1e/baf1ed3b3e94ebe4f81f067b785615d7a24426ea" alt=""
data:image/s3,"s3://crabby-images/baf1e/baf1ed3b3e94ebe4f81f067b785615d7a24426ea" alt=""
これはPower Automateのスイッチが使えるデータは「整数」か「文字列」だけなんだけど、SharePointリストの選択肢列のデータ型が「オブジェクト」だから発生するエラー。
選択肢列名にvalueがついている項目を選ぶとスイッチで使用できる
そこでこんな感じで列名にValueがついている項目を選ぶと、
data:image/s3,"s3://crabby-images/e0bde/e0bde48885c43d2733580e94941c625a24656d9f" alt=""
data:image/s3,"s3://crabby-images/e0bde/e0bde48885c43d2733580e94941c625a24656d9f" alt=""
フローは無事動く。
data:image/s3,"s3://crabby-images/3603d/3603d57a01077b5dacfd9a92774da94224bb46a5" alt=""
data:image/s3,"s3://crabby-images/3603d/3603d57a01077b5dacfd9a92774da94224bb46a5" alt=""
値が入っていない可能性のあるときのスイッチ
もし選択肢列が任意項目で値が入っていない可能性がある場合、
data:image/s3,"s3://crabby-images/96118/96118d49e358bff98626783a3274f3402789df97" alt=""
data:image/s3,"s3://crabby-images/96118/96118d49e358bff98626783a3274f3402789df97" alt=""
さっきのフローをそのまま実行すると、またエラーが発生する。
data:image/s3,"s3://crabby-images/876d3/876d3e2e2ee5b3bc36e4d0fa3217381ea487cdbe" alt=""
data:image/s3,"s3://crabby-images/876d3/876d3e2e2ee5b3bc36e4d0fa3217381ea487cdbe" alt=""
これはPower Automateのスイッチがnullを扱えないため発生するエラー。
なのでスイッチに入れる前にnullチェックをする必要があるんだけど、if文を使ってしまうとネストが深くなってしまっていまいち読みにくくなってしまう。。。
Coalesce関数を使う
そこでこちらのブログで紹介されているCoalesce関数を使用する方法でフローを書けば、かなりきれいにフローを書くことができる。
![]()
data:image/s3,"s3://crabby-images/3e206/3e206e25561707bc18f7341ed6fc998271a8c408" alt=""
Improve your switch case with coalesce in Power Automate
Within the switch don't use the Choice Value, but use the Choice value inside a coalesce function:
まずさっきの「選択肢列+Value」の項目をコピーして
data:image/s3,"s3://crabby-images/87f3a/87f3a5cc45dd2a04c1172a73fb4b74ca02afd9a5" alt=""
data:image/s3,"s3://crabby-images/87f3a/87f3a5cc45dd2a04c1172a73fb4b74ca02afd9a5" alt=""
式タブで貼りつけ。
data:image/s3,"s3://crabby-images/47fd7/47fd73b5fd0235c34b7eb4deee8b4b6f61d5739d" alt=""
data:image/s3,"s3://crabby-images/47fd7/47fd73b5fd0235c34b7eb4deee8b4b6f61d5739d" alt=""
先頭の「@{」と末尾の「}」を消したらCoalesceで囲んであげて、
data:image/s3,"s3://crabby-images/4242c/4242c59bfacabe6d20da2f46c75c7e305d77b848" alt=""
data:image/s3,"s3://crabby-images/4242c/4242c59bfacabe6d20da2f46c75c7e305d77b848" alt=""
Coalesce関数の第2引数に選択肢に含まれない適当な文字列(今回は「unknown」)を渡してあげる。
data:image/s3,"s3://crabby-images/09dc4/09dc483b4b21db0c2e0596f2886c9ab016d0c0b9" alt=""
data:image/s3,"s3://crabby-images/09dc4/09dc483b4b21db0c2e0596f2886c9ab016d0c0b9" alt=""
これでフローを実行すると選択肢列に選択がない(値がNullの)場合、文字列「unknown」がスイッチに渡されるため既定のアクションが実行される。
data:image/s3,"s3://crabby-images/d766c/d766c50726668ec29ff8558fa6760e8677613edd" alt=""
data:image/s3,"s3://crabby-images/d766c/d766c50726668ec29ff8558fa6760e8677613edd" alt=""
わりと単純な工夫だけど使いやすい方法だったのでメモ。
コメント