1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

【PowerAutomate】2つのjson形式のデータに対して差分結果を出力する方法

Posted at

初めに

この記事ではクラウドフローである「PowerAutomate」で2つのjson形式のデータを突合させオブジェクトごとに差分や共通している部分を出力させる方法になります。
ただし、条件として2つのjsonで使われれているキーが一致していることが絶対になります。
キーが少しでも違うと同士を突合することは出来ません。
必ず突合する時は、キーが一致されているように事前にjsonのデータを成形してください。
開発している中で差分や一致しているデータのみを出力させたい場合に、参考になればと思います。

やりたいことのイメージ

やりたいことは①~③の部分をそれぞれ抽出する方イメージです。
image.png

今回、メインとなる処理

今回は 「アレイのフィルター処理」 がメインの処理となります。
image.png

テストデータ

今回はjson(A)とjson(B)を用意して差分結果の出力を確認してみます。
ご自身の開発環境で試したい場合はコピーしてご活用ください。

json(A)
[
{
"商品コード":100,
"商品名":"リンゴ",
"個数":"1個"
},
{
"商品コード":200,
"商品名":"バナナ",
"個数":"4個"
},
{
"商品コード":300,
"商品名":"ぶどう",
"個数":"3個"
},
{
"商品コード":400,
"商品名":"モモ",
"個数":"7個"
},
{
"商品コード":500,
"商品名":"ミカン",
"個数":"15個"
}
]
json(B)
[
{
"商品コード":300,
"商品名":"ぶどう",
"個数":"3個"
},
{
"商品コード":400,
"商品名":"モモ",
"個数":"7個"
},
{
"商品コード":500,
"商品名":"ミカン",
"個数":"15個"
},
{
"商品コード":600,
"商品名":"梨",
"個数":"5個"
},
{
"商品コード":700,
"商品名":"スイカ",
"個数":"1個"
}
]

テストフロー

今回のテストフローはこんな感じ。(超シンプルです)
フロー作成のやり方は...
1.「手動でフロートリガーします」を選択しフローを新規作成。
2. 組み込み>データ操作>作成を選択。json(A)とjson(B)をそれぞれ入力します。
3. 2つのjsonデータを用意することができたら、組み込み>データ操作>アレイのフィルター処理を選択
image.png

「アレイのフィルター処理」の詳細モードはこんな感じ
image.png

次のセクションから、アレイのフィルター処理に式を入力し結果が変化することを確認していきましょう。

処理結果

image.png

①と③の結果出力

①の部分(json(A)だけにある情報)を抜き出したい場合は...
 ・差出人を「outputs('json(A)')
 ・条件の左側に「contains(outputs('json(B)'), item())
 ・条件の真ん中は「次の値に等しくない
 ・条件の右側は「true
と入力してください。
image.png
結果は以下のようになると思います。

①の結果
[
  {
    "商品コード": 100,
    "商品名": "リンゴ",
    "個数": "1個"
  },
  {
    "商品コード": 200,
    "商品名": "バナナ",
    "個数": "4個"
  }
]

③の部分を求めたい場合はjson(A)とjson(B)の記述を逆にすればよいです。
 ・差出人を「outputs('json(B)')
 ・条件の左側に「contains(outputs('json(A)'), item())
 ・条件の真ん中は「次の値に等しくない
 ・条件の右側は「true

結果は以下の通り。

③の結果
[
 {
   "商品コード": 600,
   "商品名": "梨",
   "個数": "5個"
 },
 {
   "商品コード": 700,
   "商品名": "スイカ",
   "個数": "1個"
 }
]

②の結果出力

json(A)とjson(B)の共通部分を求める場合は条件の真ん中を「次の値に等しい」を選択してください。
image.png
結果は以下の通りです。

②の結果
[
 {
   "商品コード": 300,
   "商品名": "ぶどう",
   "個数": "3個"
 },
 {
   "商品コード": 400,
   "商品名": "モモ",
   "個数": "7個"
 },
 {
   "商品コード": 500,
   "商品名": "ミカン",
   "個数": "15個"
 }
]

contains関数についてちょっと解説

今回使ったcontains関数(contains(A,B))ですが、これはAの中にBが含まれていればtureを返します。含まれていない場合はfalseを返す関数となっています。

アレイのフィルター処理でjsonを使うと差出人に指定したjsonの{}を含めたオブジェクトごとを1ずつ突合してくれます。
よって、差出人に記載している{}の数だけ毎回突合をしてもらい、それぞれに対してtureとfalseを返してくれます。
(冒頭で記載した「条件として2つのjsonで使われれているキーが一致していること」はこれが理由になります。)
詳しくはMicrosoftのドキュメントをご確認ください。

最後に

長々と説明しましたが、実際に動かしてみた方が理解しやすいと思いますので、今回用意したテストデータとフローを作成し実際に確認してみてください。
理解した後、活用したい箇所にフロー追加をしてください。

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?