【PowerAutomate】複数の文字を同時に置換する。replaceをループで処理して式を見やすくする方法も。

スポンサーリンク




作業を自動化する
  • 複数の文字をreplaceで置換したい
  • replaceがいくつも重なって式が見にくい

この記事では、そんな方に複数の文字を同時に置換する方法を紹介します。

みずしぶき
みずしぶき

説明する2つのreplaceの使い方はどちらも利点があるので、両方使えるようになりましょう。

スポンサーリンク

(1)複数の置換を1つの式で書いた場合

元の文字を変数の「変数を初期化する」で指定しておきます。

私は●名前●です。今日は●日付●です。

アクションはこちらのサンプルをコピーして使用してください。

{"id":"5b4028e3-c6c1-43e2-9a12-65687a46c39a","brandColor":"#770BD6","connectionReferences":{},"connectorDisplayName":"変数","icon":"","isTrigger":false,"operationName":"変数を初期化する","operationDefinition":{"type":"InitializeVariable","inputs":{"variables":[{"name":"変換対象","type":"string","value":"私は●名前●です。今日は●日付●です。"}]},"runAfter":{}}}

データ操作の「作成」に変換対象のコピーを作成します。

variables('変換対象')

次のアクションで変数「変換対象」に置換後のデータを入れますが、
式の中に自分自身である「変換対象」を指定できないので、ここでコピーを作成しておきます。

変換の「変数の設定」に置換用の式を書きます。

replace(replace(outputs('変換対象コピー'),'●名前●','藤井'),'●日付●','1月1日')

2セットの置換を行うのでreplace関数にreplace関数で囲むように書きます。
このような書き方をネストと言います。

{"id":"fefeed03-3719-4f6f-9fa6-9183850f51a7","brandColor":"#8C3900","connectionReferences":{},"connectorDisplayName":"制御","icon":"","isTrigger":false,"operationName":"スコープ","operationDefinition":{"type":"Scope","actions":{"変換対象コピー":{"type":"Compose","inputs":"@variables('変換対象')","runAfter":{}},"変数の設定":{"type":"SetVariable","inputs":{"name":"変換対象","value":"@{replace(replace(outputs('変換対象コピー'),'●名前●','藤井'),'●日付●','1月1日')}"},"runAfter":{"変換対象コピー":["Succeeded"]}}},"runAfter":{"変数を初期化する":["Succeeded"]}}}

フローを動かした結果。2セットの置換ができました。

この方法でも置換は成功するので問題ありません。
アクションが少なくてフロー全体で見ればスッキリしています。

ですが3点どれかに当てはまる場合はループを使った方法をおすすめします。

  • 後で文字を変更する
  • 見やすさを重視したい
  • 置換対象が増える

(2)複数の置換をループで書いた場合

元の文字を変数の「変数を初期化する」で指定しておきます。※先ほどと同じ

私は●名前●です。今日は●日付●です。

アクションはこちらのサンプルをコピーして使用してください。

{"id":"a4a8d887-35d1-4c62-817f-882cf9208a59","brandColor":"#770BD6","connectionReferences":{},"connectorDisplayName":"変数","icon":"","isTrigger":false,"operationName":"変数を初期化する","operationDefinition":{"type":"InitializeVariable","inputs":{"variables":[{"name":"変換対象","type":"string","value":"私は●名前●です。今日は●日付●です。"}]},"runAfter":{}}}

変換情報をデータ操作の「作成」で指定します。

[
  {
    "変換前": "●名前●",
    "変換後": "藤井"
  },
  {
    "変換前": "●日付●",
    "変換後": "1月1日"
  }
]

この書き方はJSONオブジェクトです。コレクションとも呼ばれます。
変換したい文字がセットになって並んでいるので、見やすく後から編集がしやすいです。

>>カッコ{}を使ったJSON表記の詳しい使い方

アクションはこちらのサンプルをコピーして使用してください。

{"id":"fc816cf3-75a1-4798-acd5-0d8ea2cd8bcb","brandColor":"#8C3900","connectionReferences":{},"connectorDisplayName":"制御","icon":"","isTrigger":false,"operationName":"スコープ","operationDefinition":{"type":"Scope","actions":{"変換情報":{"type":"Compose","inputs":[{"変換前":"●名前●","変換後":"藤井"},{"変換前":"●日付●","変換後":"1月1日"}],"runAfter":{}},"Apply_to_each":{"type":"Foreach","foreach":"@outputs('変換情報')","actions":{"変換対象コピー":{"type":"Compose","inputs":"@variables('変換対象')","runAfter":{}},"変数の設定":{"type":"SetVariable","inputs":{"name":"変換対象","value":"@{replace(outputs('変換対象コピー'),items('Apply_to_each')?['変換前'],items('Apply_to_each')?['変換後'])}"},"runAfter":{"変換対象コピー":["Succeeded"]}}},"runAfter":{"変換情報":["Succeeded"]},"runtimeConfiguration":{"concurrency":{"repetitions":50}}}},"runAfter":{"変数を初期化する":["Succeeded"]}}}

Apply to eachの内容は変更不要なので説明は省きます。

フローを動かした結果。2セットの置換ができました。

replaceを複数ネストしたフローと同じ結果になりました。

スポンサーリンク

まとめ

PowerAutomateで複数の文字を同時に置換する方法を紹介しました。

フローにループを使う・使わないは重視する内容によって変わってきます。2種類の方法を知っているとイメージした通りのフローを作れるようになるので覚えておいてください。

PowerAutomateのおすすめ記事
人気ページ
Apply to eachの使い方
アレイのフィルター処理の使い方
日付関数の使い方
エラーを無視する方法
メールの内容をExcelへ転記
メール本文から名前を抽出

>>PowerAutomateの記事一覧を見る<<

お気に入り必須!公式ページ
Microsoft Power Automate
式関数のリファレンス
コネクタのリファレンス
Excel Online (Business)のリファレンス

最後まで読んで頂き、ありがとうございます。

「この記事が参考になった」「お礼でコーヒー代をプレゼントしよう」という方がいましたらチップ(15円〜)をお願いいたします。

Amazonギフト券- Eメールタイプ - Amazonベーシック

メールのあて先は 「mizusibuki8080@gmail.com」です。
※上記のアドレスは投げ銭受け取り専用です。他のメールは受け取れない設定にしてあるのでご注意ください。

作業を自動化する
ネットワークエンジニアになった人
タイトルとURLをコピーしました