概要
今回は 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 をカスタムオブジェクトに変換する」アクションで変換します。
これまで空白文字に置換せず参照するとエラーになっていましたが、
このように問題なく参照できます。
空白文字に置換した場合との違い
ついでに空白文字と空白の値<空白>にどのような違いがあるのか調べました。
サンプルの JSON を「テキストを置換する」アクションで空白文字にした場合
blog_url に<空白>の文字はありません。
参照した場合は空のテキスト値になっています。
Byte数を見てみる
一時ファイルを作成し空白文字と空白の値<空白>をそれぞれUTF-8BOMなしで書き込みました。それをバイナリ データーに変換してByte数をみましたが両方とも0Byteとなっていて違いはありませんでした。特に面白くないので割愛します。興味がある方はサンプルを動かしてみてください。
その他気づいたこと
まとめ
- テキストの空白文字とは異なり、新たに「空白の値<空白>」として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