概要
Power Automateで変数を外出ししたい要望とは、ある程度Power Automateをいじくってくると出てきます。特にメッセージ関連。メッセージフォーマットだけ変えたいんよ、そんでもってフローが複数にまたがるんや――そんなわけで、変数を設定ファイルで取り扱えるようにしました。Power Automateで設定ファイルを作ってSwitchを使ってもういやだ、そんなのはもう味わいたくない人向けです。
もともとは、下記のフローを切り出した内容です。
読み込む設定ファイル
設定ファイルは、以下のような感じのファイルを、key/value=プロパティ名/値として読み込みます。sがなぜついているかは、PowerAutomateはvalueはよく使われるので非常に紛らわしくなるためです。
全体のフローと利用方法
設定ファイルを読み込み、変数を読み込むまでを実装しています。
このフローは、パーツ利用(コピペ)を想定しています。スコープ内のスコープ(1)(2)といった単位で適宜コピーしやすいように構成しています。
このページで紹介するのは(1)(2)です。(1)で設定ファイルを読み込み、(2)で変数を取得する役割を持ちます。
(1)設定ファイルを読み込む
このスコープは設定ファイルを読み込み、フロー内で取り扱えられるようになります。Excelから直接変数に値を取り込む場合、IF文の縦展開やらSwitch文の横展開やらえらい羽目になります。それらを回避したいため、アレイで読み込みます。アレイは一次元配列しか取り込めないみたく勝手に思い込んでましたが、どうやら複雑な配列もどんとこいのようです。
この(1)は、設定ファイルの読み込みのため、フローの最初の1回目だけ実行します。
(1-1)設定ファイルを読み込む
- 「Excel」の「表内に存在する行を一覧表示」を利用。
- 設定ファイルを指定します。ここではテスト用フォルダにあるsetting.xlsxファイルを使います。
(1-2)key/valueで読み込む
(2)keyの値を取得する
このスコープは、上記で取得した設定情報から一意のkeyのvalueを取得します。これにより、必要になったタイミングで必要になった変数を定義し、利用することが可能になります。
(2)は(1)と異なり、変数を取得したい毎に毎回実行します。
変更箇所は、以下の通り。
- (2-1)env
- (2-3)変数の設定/名前
(2)を実行する直前で変数を定義し、上記の変更箇所を修正して読み込む、てのが一番わかりやすく、どの変数をどのタイミングで定義したのかがわかりやすいです。
(2-1)keyのデータ取得
- (1-2)の設定情報から取得したいkeyにのみデータを絞り込みます。今回の場合は"env"
- 「データ操作」の「アレイのフィルター処理」を利用。
- 「本文」は(1-2)の出力データ
- keyは、(1-2)で指定したkeyを取得するための「item()?['key']」
(2-2)データをJSON解析する
データは(2-1)で一意に取得したはずですが、形状はJSON形式のままなので、これを変換します。
- (2-1)で絞り込んだデータを、JSON解析をかけます。成功すると、変数に「key」と「value」が選べるようになります
- 「データ操作」の「JSONの解析」を利用
- 「コンテンツ」は(2-1)の出力
- スキーマは以下。コピペの場合、変更は不要です。
{
"type": "array",
"items": {
"type": "object",
"properties": {
"key": {
"type": "string"
},
"value": {
"type": "string"
}
},
"required": [
"key",
"value"
]
}
}
(2-3)valueを取得する
- アレイ扱いのためどうしてもこうなる。
- 「コントロール」の「Apply to each」を利用
- 「以前の手順から出力を選択」には、(2-2)の「本文」を指定します
使用例
実際の使用例としては、以下のような感じで使います。
- (1)設定ファイルを読みこみたいファイルに設定します。
- (1)(2)のスコープをそれぞれコピーします。
- (1)(2)を使いたいフローにペーストします。
- (2)を以下のような感じで編集します。変数名とkeyは、統一しておくとどのデータを読み込んだか名称でわかるので便利です。
(1)(2)のフローは、基本使う設定ファイルを指定し、コピペ用のフローを作って準備しておきます。そうすると、複数フローにまたがっても、変数の取得をスムーズに行えるようになるかと思います。