Power Apps JSONを解析する関数「ParseJSON」を詳しく解説|WebAPIとの連携方法も

ParseJSON関数がGAになったようなので、使い方を詳しく調べてみた。

ParseJSON関数

ParseJSON関数は、その名前の通りJSON形式のテキストをPower Appsで使用できるデータに変換(解析)する関数

JSONは色々な情報を1つのテキストで表現できるデータの形式で、APIの戻り値とかCosmosDBとか色々なところで使われている。

こちらはうちのねこの情報をJSONで表してみたもの。

{
    "Age": 3,
    "Name": "こつぶ",
    "Species": "スコティッシュフォールド",
    "VaccinationHistory": [
        {
            "date": "2023-06-01",
            "name": "3種混合"
        },
        {
            "date": "2022-06-01",
            "name": "3種混合"
        },
        {
            "date": "2021-06-01",
            "name": "3種混合"
        }
    ]
}

型指定されていないオブジェクト(Untyped object)

ParseJSON関数を使用すると、戻り値として「Untyped object」型のデータが返ってくる

Untyped objectは、Power Apps側がどんなタイプ(文字列?数字?オブジェクト?)の情報なのかわからない、データのこと。

そこでParseJSONで取得した値は、関数を使用してPower Appsのデータ型に変換してあげなきゃ使えない、

はずだったんだけど、どうやら文字列とか数字くらいの単純なデータならある程度推量して使うことができるようになったっぽい。
※プレビューのときには確かできなかったはず。。

こんな感じで数字型のデータとかであれば、特に変換する必要もなく直接使用することができる。

とは言えきちんと変換関数を呼んであげた方がコードを読む側にも親切なので、代表的な変換関数を少しご紹介。

文字列

ParseJSONで取得したデータをテキスト型に変える場合は、Text関数を使用する。

数字

続いて、ParseJSONで取得した値を数字型に変える場合はValue関数を使用。

日付

日付に変換したい場合はDateValue関数を、
日付と時刻に変換したい場合はDateTimeValue関数を使用する。
※文字列はISO8601形式である必要あり
ISO 8601 - Wikipedia

レコード

レコード型(オブジェクト)の場合は、取得したプロパティをドット「.」でつないでいってあげて、変換してあげればOK

配列

配列型の場合は、こんな感じでForAll関数を使用して、Power Appsで扱えるテーブル型のデータに変換してあげる。

HTTPリクエストで返ってくるJSONをPower AppsでParseする

最後に簡単なサンプルとしてこちらのサイトのAPIを使用させていただいて、郵便番号から住所を取得してみる。
郵便番号検索API - zipcloud
日本郵便が公開している郵便番号データを検索する機能をRESTで提供しています。
まずはこんな感じで「HTTPリクエストを送って住所を取得して、その戻り値のJSONを返すだけ」の単純なPower Automateを作成。
そしたらそのPower Automateを呼んであげて戻り値を変数に入れる。
返ってくるJSONはこんな感じ。
このJSONをParseJSONを使用して中身を掘ってあげると、住所が取得できる。

ということでParseJSONは非常に便利なので、今後使用することは増えていきそう。

コメント

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