技術情報ブログ
Power Platform
2022.06.01

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(Power AppsやPower Automateなど)を用いてお客様の業務を自動化するご支援を数多く承っております。

    業務の中で、「普段手動でやっている業務を自動化できないか」というような疑問がある場合には、お気軽にアーティサン株式会社までお問い合わせください。

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

    小刀稱知哉

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

    1990年4月9日生まれ

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

    趣味は読書

    Power Platform(SharePoint・Power Apps・Power Automate)に関する営業活動や設計、開発などを担当しております!

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

    Power Apps:キャンバスアプリでレスポンシブ レイアウト対応のアプリを作成する際の設計方針(1)

    2023.02.22

    今さら聞けないPower Automate:フローの種類とその違い(2)

    2023.02.08

    今さら聞けないPower Automate:フローの種類とその違い(1)

    2023.01.25

    【2023年1月更新】Power Automate 初心者 ~ 中級者 向けロードマップ

    2022.08.18

    【2023年1月更新】Power Apps の実践的なノウハウ まとめ

    2021.06.23

    【Power AutomateでExcelデータをSharePointにインポートするために考えること 第1回】4つのシーンごとに手法を比較、その最適解とは?

    2
    2021.07.14

    【Power AutomateでExcelデータをSharePointにインポートするために考えること 第2回】フロー作成でエラー発生!

    3
    2021.09.03

    【Power AutomateでExcelデータをSharePointにインポートするために考えること 第8回】トリガーの条件の指定方法

    4
    2020.10.02

    世界に広がる Power Apps「モデル駆動型アプリ」のココがスゴイ!【第1回】

    5
    2022.02.16

    SharePointのビューに擬似的なアクセス制限をかける方法(1)

    --------------------------------------------------->
    モデル駆動型アプリPower AppsPower PlatformSharePointExcelPower AutomateC#attributevalidationローコードAngularAccessInfoPathMatTableAngular Materialデータ構造SortByColumns関数TypeScriptHTMLEF CoreマイグレーションFramework CoreAttribute directivesO/Rマッパーazure sql databaseCase式HTTP RequestCSSxUnit.Net Core 3.1VSCode.Net Core Test ExplorerDataverse for Teamsitem関数Google MapsMarker ClustererRANK()関数Dynamics 365 SalesMicrosoft TranslatorマーカークラスタリングライブラリtailwindcssマルチテナントドロップダウンメニューBreakpointObserverメディアクエリスマホPCレスポンシブ入門初心者中級者キャンバスアプリDatePickerDropdownビューアクセス制限承認リマインドSetForAllUpdateContextロードマップ技術ItDX情報技術メッセージIDメールfirst()関数nest入れ子動的リストcollectionコレクション複数の添付ファイル承認フローformエクスポートインポートカスタマイズcomponentダイアログコンポーネントdialogTips新機能変数検索Microsoft 365グループセキュリティグループ送信元メールの送信差出人インスタントクラウドフロー自動化したクラウドフロー委任VBAエラーエクセルerror復元restorePower BI個人列ユーザー列SharePoint Onlineリスト非表示アプリ[市民開発者構築自動化したクラウド フローフローの種類インスタント クラウド フロースケジュール済みクラウド フローレスポンシブ レイアウトresponsive layout
    PageTop
    ページトップに戻る