技術情報ブログ
Power Platform
2022.06.01

Power Automate:複数(動的)の添付ファイルをメールで送信する方法

Power Automate:複数(動的)の添付ファイルをメールで送信する方法

こんにちは。アーティサン株式会社の小刀稱(ことね)です。

Power Automateでは、メールを送信する際、ファイルを添付することができます。

添付するファイル数が決まっている場合は、簡単に実装できますが、添付ファイル数が都度異なる(動的である)場合は、一工夫が必要となります。

そこで、今回はPower Automateで複数(動的)の添付ファイルをメールで送信する方法について說明します。
また、「メールの送信」アクションと「承認」アクションでは、実装方法が異なりますので、併せてご紹介します。

内容としては、既にPower Automateでフローを作成したことがある方に向けた記事です。
Power Automate初心者の方は、以下の記事も参考にしてください。

 

前提

SharePointリストの「添付ファイル」列にファイルが格納されています。
この添付ファイルを取得し、メールを送信するという流れです。

SharePointリストの添付ファイル列
SharePointリストの添付ファイル列

Power Automateを用いて、メールを送信する際、以下の2パターンの状況が考えられます。

以下では、それぞれのパターンに関する実装方法を說明します。

 

「メールの送信」アクションを用いる

まずは、「メールの送信」アクションを用いる場合です。
作成したフローは以下のとおりです。

複数(動的)の添付ファイルをメールで送信する際は、配列(アレイ)を用います。

「メールの送信」アクションを用いて、添付ファイルを送信
「メールの送信」アクションを用いて、添付ファイルを送信

フローのポイントは以下2点です。

  • 「配列変数に追加」アクション

  • 「メールの送信」アクション

 

「配列変数に追加」アクション

「配列変数に追加」アクション
「配列変数に追加」アクション

「配列変数に追加」アクションの値を以下に設定してください。

{
  "Name": @{item()?['DisplayName']},
  "ContentBytes": @{body('添付ファイルのコンテンツの取得')}
}

このフローを実行した際の attachmentsForOutlook の値は以下となります。
$content-type$contentの内容は、添付ファイルの種類や中身によって異なります。

[
  {
    "Name": "添付1.docx",
    "ContentBytes": {
      "$content-type": "application/vnd.openxmlformats-officedocument.wordprocessingml.document",
      "$content": "UEsDBBQABgAIAAAAIQB~"
    }
  },
  {
    "Name": "添付2.xlsx",
    "ContentBytes": {
      "$content-type": "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
      "$content": "UEsDBBQABgAIAAAAIQB~"
    }
  }
]

ちなみに、SharePointリストではなく、ドキュメントライブラリからコンテンツContentBytesを取得する場合は、 ファイルコンテンツの取得パスによるファイルコンテンツの取得アクションを用いてください。

 

「メールの送信」アクション

「メールの送信」アクション
「メールの送信」アクション

アクションを追加した最初の状態では、添付ファイルに配列を設定することができません。
よって、添付ファイルの右端にあるアイコンをクリックして、配列を設定できるよう変更します。
その後、配列(attachmentsForOutlook)を設定します。

 

実行結果

それでは、フローを実行してみましょう。

実行結果-「メールの送信」アクション
実行結果-「メールの送信」アクション

メールにファイルが添付されました!

 

「承認」アクションを用いる

続いて、「承認」アクションを用いる場合です。

注意点

  • 「承認」アクションを用いた場合、OutlookとTeamsに通知されます。
    Power Automateの仕様として、Outlookにはファイルが添付されますが、Teamsには添付されません。(2022年5月時点)

  • Teamsでファイルを参照したい場合は、ファイルへのリンクを本文に記載するなどにより対応してください。
    (機会があれば、こちらの方法についてもブログを作成します!)

    作成したフローは以下のとおりです。

    「承認」アクションを用いて、添付ファイルを送信
    「承認」アクションを用いて、添付ファイルを送信

    フローのポイントは以下2点です。

    • 「配列変数に追加」アクション

    • 「承認」アクション

     

    「配列変数に追加」アクション

    「配列変数に追加」アクション
    「配列変数に追加」アクション

    「配列変数に追加」アクションの値を以下に設定してください。

    {
      "Name": @{item()?['DisplayName']},
      "Content": @{body('添付ファイルのコンテンツの取得')}
    }
    ※「メールの送信」アクションの場合は、ContentBytesでしたが、「承認」アクションの場合は、Contentとなります。

     

    「承認」アクション

    「承認」アクション
    「承認」アクション

    アクションを追加した最初の状態では、添付ファイルに配列を設定することができません。
    よって、添付ファイルの右端にあるアイコンをクリックして、配列を設定できるよう変更します。
    その後、配列(attachmentsForApproval)を設定します。

     

    実行結果

    それでは、フローを実行してみましょう。

    実行結果-「承認」アクション
    実行結果-「承認」アクション

    Outlookにはファイルが添付されています。
    前述したとおり、Teamsにはファイルは添付されていません。

     

    さいごに

    本記事では、はPower Automateで複数(動的)の添付ファイルをメールで送信する方法について說明しました。
    また、「メールの送信」アクションと「承認」アクションでは、実装方法が異なりますので、併せてご紹介しました。

    参考としていたいだければ幸いです!

    Power Platform(SharePoint・Power Apps・Power Automate)に関する営業活動や設計、開発などを担当:小刀稱知哉

    小刀稱知哉

    大分県出身(温泉大好き)、現在は東京都在住

    1990年生まれ

    30才でメーカーの技術営業からIT業界にジョブチェンジ!!!

    趣味は読書

    主にMicrosoftのローコード(SharePoint・Power Platform)に関するに関する営業活動や設計、開発などを担当しております!

    (最近はCopilot Studioについても勉強中)

    持ってる資格はPL-200/PL-300/PL-400/PL-600/MS-700/AZ-104/AZ-305/SC-200/SC-100

    シェアする
    記事カテゴリ
    最新記事
    2025.05.13

    元自治体職員(地方公務員)がCopilot Studioを使って業務に役立つエージェント活用を考えてみた

    2025.05.14

    Copilot Studioは安全?機密情報漏洩のリスクを低減する方法

    2025.05.07

    SharePointでスライドショーを実装したい!効果的な3つの方法を解説

    2025.04.30

    Power Apps, Power Automate で作る NFC タグを活用したアプリ例

    2025.04.16

    Power Apps で NFC タグを使ってみる

    データ構造.Net Core Test Explorerレスポンシブ技術カスタマイズ委任自動化したクラウド フロー運用開発環境filter query管理システム列X-SPNFCタグモデル駆動型アプリSortByColumns関数Dataverse for Teams入門ItcomponentVBAフローの種類選択肢列環境sortガバナンス登録日StyleDLPポリシーPower AppsTypeScriptitem関数初心者情報技術ダイアログエラーインスタント クラウド フロー参照列本番環境ソートerror notification更新者StudioPowerAutomatePower PlatformHTMLGoogle Maps中級者メッセージIDコンポーネントエクセルスケジュール済みクラウド フローChatGPTライセンスmultiple itemエラー通知更新日AIX-SP DesignSharePointEF CoreMarker Clustererキャンバスアプリメールdialogerrorレスポンシブ レイアウトOpenAI環境構築手順複数項目削除変更生成系AIスライドショーExcelマイグレーションRANK()関数DatePickerfirst()関数Tips復元responsive layoutオープンAIpipelineシェアポイントフォルダ外部DBCopilotSlide showPower AutomateFramework CoreDynamics 365 SalesDropdownnest新機能restoreデータ行の制限チャットGPTCI/CD便利機能ゴミ箱連携license比較C#Attribute directivesMicrosoft Translatorview入れ子変数Power BI引き継ぎgalleryパイプラインカレンダー完全削除接続添付ファイルコントロール地方自治体attributeO/Rマッパーマーカークラスタリングライブラリビュー動的リスト検索個人列退職ギャラリーDevOpsCalendarモデル駆動型データフローファイルサイズCopilot Studiotvalidationazure sql databasetailwindcssアクセス制限collectionMicrosoft 365グループユーザー列所有者を変更スクロールMicrosoft 365Teamsセキュリティロールrecycle binフルリモートワーク自治体DXローコードCase式マルチテナント承認コレクションセキュリティグループSharePoint Online異動コンテナ簡易在庫管理ローコード開発ビジネスルールごみ箱アーティサン生成AI自治体AngularHTTP Requestドロップダウンメニューリマインド複数の添付ファイル送信元リストLoopショートカットキー時間外非エンジニアDataverseアクセス許可Artisan事例AccessCSSBreakpointObserverSet承認フローメールの送信非表示Microsoftshortcut key通知体験談JavaScriptSharePoint Framework転職活用InfoPathxUnitメディアクエリForAllform差出人アプリdesignconcat関数ファイル勉強表示SPFx主キーMatTable.Net Core 3.1スマホUpdateContextエクスポートインスタントクラウドフロー[市民開発者JSON文字制限フィルター クエリ内製化切替サンプルCopilot StudioAngular MaterialVSCodePCロードマップインポート自動化したクラウドフロー構築デザインフロー実行ドキュメント ライブラリ市民開発登録者samplePowerApps
    PageTop
    ページトップに戻る