LoginSignup
1
0

Power Automate for desktop 「 null ハンドリングのこと」

Posted at

概要

今回は Power Automate for desktop における null ハンドリングの話です。
直近のアップデートではPicture-in-PictureやPower Fxの話題が多く取り上げられています。しかし個人的に一番嬉しいのは JSON 形式のデータをカスタムオブジェクト型に変換するとき null ハンドリングのための処理が必要なくなったことです。やらなくてよくなったことをわざわざ書くなよと思いますが、思い入れが深いので書きました。

環境

  • Windows 11 Pro 23H2
  • Power Automate for desktop 2.41.170.24032 インストーラー版
  • 2024年2月末の情報です

Before

null ハンドリングされているのに気付いたのはこのバージョンでのことですが、1月末のアップデートで null のことが載っているのでそこで変わったのだと思います。

これまでは JSON の文字列内で null を検索して空白文字 "" に置換していました。これを行わないでnull値を参照するとエラーになっていました。かれこれ2年以上前の記事に対策などまとめてあります。APIを叩くときはほぼ必須でしたが、これでほぼ出番はなくなりそうです。

After

このようなJSONがあったとします。

{
    "test":{
        "name":"hoge",
        "age":3,
        "blog_url":null,
        "list_sample":[
            "zero",
            "one",
            "two",
            "three"
        ]
    }
}

これを「JSON をカスタムオブジェクトに変換する」アクションで変換します。

null は<空白>という表示になります。
image.png

これまで空白文字に置換せず参照するとエラーになっていましたが、

このように問題なく参照できます。

image.png

空白文字に置換した場合との違い

ついでに空白文字と空白の値<空白>にどのような違いがあるのか調べました。

サンプルの JSON を「テキストを置換する」アクションで空白文字にした場合
image.png
blog_url に<空白>の文字はありません。
image.png
参照した場合は空のテキスト値になっています。
image.png

Byte数を見てみる

一時ファイルを作成し空白文字と空白の値<空白>をそれぞれUTF-8BOMなしで書き込みました。それをバイナリ データーに変換してByte数をみましたが両方とも0Byteとなっていて違いはありませんでした。特に面白くないので割愛します。興味がある方はサンプルを動かしてみてください。
image.png

その他気づいたこと

  • 空白の値<空白>はデバッグ中に一時停止したとき、手動で値を書き換えることができません
    image.png
  • 空白文字へ置換した場合はテキスト値の空なので手動で一時的に書き換えが可能です
    image.png

まとめ

  • テキストの空白文字とは異なり、新たに「空白の値<空白>」としてnullハンドリングされるようになりました
  • これに伴い参照時エラーがなくなったので空白文字に置換する必要がなくなりました

長きにわたりPower Automate for desktop から API を叩くとき、null ハンドリングに苦しめられてきたのでとても個人的には嬉しいアップデートでした。

検証サンプル

SET SampleJson TO $'''{
    \"test\":{
        \"name\":\"hoge\",
        \"age\":3,
        \"blog_url\":null,
        \"list_sample\":[
            \"zero\",
            \"one\",
            \"two\",
            \"three\"
        ]
    }
}'''
Text.Replace Text: SampleJson TextToFind: $'''(?<=:\\s*)null(?=\\s*|,|})''' IsRegEx: True IgnoreCase: True ReplaceWith: $'''\"\"''' ActivateEscapeSequences: False Result=> Replaced
Variables.ConvertJsonToCustomObject Json: Replaced CustomObject=> JsonAsCustomObject1
Variables.ConvertJsonToCustomObject Json: SampleJson CustomObject=> JsonAsCustomObject2
SET NewVar1 TO JsonAsCustomObject1.test.blog_url
SET NewVar2 TO JsonAsCustomObject2.test.blog_url
File.GetTempPath TempFile=> TempFile1
File.GetTempPath TempFile=> TempFile2
File.WriteText File: TempFile1 TextToWrite: JsonAsCustomObject1.test.blog_url AppendNewLine: False IfFileExists: File.IfFileExists.Overwrite Encoding: File.FileEncoding.UTF8NoBOM
File.WriteText File: TempFile2 TextToWrite: JsonAsCustomObject2.test.blog_url AppendNewLine: False IfFileExists: File.IfFileExists.Overwrite Encoding: File.FileEncoding.UTF8NoBOM
File.ConvertToBinary File: TempFile1 BinaryData=> BinaryData1
File.ConvertToBinary File: TempFile2 BinaryData=> BinaryData2
@@copilotGeneratedAction: 'False'
Scripting.RunPowershellScript.RunPowershellScript Script: $'''$src = [System.IO.File]::ReadAllBytes(\"%TempFile1%\")
Write-Output $src |Format-Hex''' ScriptOutput=> PowershellOutput1
@@copilotGeneratedAction: 'False'
Scripting.RunPowershellScript.RunPowershellScript Script: $'''$src = [System.IO.File]::ReadAllBytes(\"%TempFile2%\")
Write-Output $src |Format-Hex''' ScriptOutput=> PowershellOutput2
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