この記事は、Microsoft Power Automate Advent Calendar 2024 13日の金曜日担当分の記事です
はじめに
業務改善の一環として、デスクトップの自動化を図るためにPower Automate for desktopを活用しています。
デスクトップ上の処理を自動化するための便利なアクションが様々あり、一部にはクラウドコネクタも存在します。
その中で「SharePoint」コネクタがあるのですが、今回はSharePoint(SPO)上のファイルをローカルにダウンロードしたい場面で使ってみました。
簡単な記事ですが、現場からお届けします🤖

⚠️SharePointアクションはPower Automate Premiumライセンスが必要となります。
どのような場面で使用したか
このアクションを使った業務シナリオとして、SPOドキュメントライブラリに保存されたCSVファイル等を、Excel Power Queryで加工し、その結果をWEBシステムに登録するといったものです。
元ネタとなるCSVファイル等がSPO上にあるため、クラウドフローで完結したいところですが、Excelでの加工や、WEBブラウザを介したシステム登録などかくかくしかじかで、一度ローカルにデータを保存したいと考えていました。

OneDriveアプリで元ネタが保存されているフォルダと同期をとる事も考えましたが、保存されたファイルの同期に時差が生じることもあり、処理がスムーズに進行しない場合もありました
そのことについて、他の手段がないか検索していると、Power Automate for desktopでSharePointファイルをダウンロードする内容の記事を見つけ、同じように試してみたところ、滞りなくフローが完結するようになりました。
アクションの設定
今回はSPOに保存されたCSVファイル「Masukarasu.csv」をデスクトップ上に作成するシナリオで進めていきます。

使用するのは以下の2つのアクションです👇
- SharePointアクション「パスによるファイルコンテンツの取得」
- ファイルアクション「バイナリデータをファイルに変換」

1. ファイルコンテンツの取得
まず、1つ目のアクションでSPO上のファイルコンテンツを取得します。サイトのアドレスにはファイルが保存されたSPOサイトのアドレスを指定し、ファイルパスには取得したいファイルのパスを設定します。
2. ファイルの作成
次に、取得したファイルコンテンツを使用してファイルを作成します。「バイナリデータ」には、「パスによるファイルコンテンツの取得」アクションで生成された変数「GetFileContentByPathResponse」を設定し、「ファイルパス」には保存したいパス(ファイル名含む)を設定します。

結果として、SPO上のCSVファイルをデスクトップ上に作成することができました。

複数のファイルや特定のファイル形式への対応も
複数のファイルの処理
プロセスによっては、一度に複数ファイルを取得し処理を進める必要がありました。Power Automate for desktopでは、その他のアクションを用いることで特定のフォルダ内のすべてのファイルを対象にしたり、条件に合うファイルだけを抽出したりすることができます。例えば、SPOの特定のフォルダにあるすべてのファイルを処理したいといったケースでは、「フォルダーの一覧」アクションを使い、SharePointフォルダーに含まれているファイル情報を取得することで対応できます。
ファイル形式のチェック
処理するファイルの形式を限定したい場合もあります。例えば、テキストファイル(txt)だけを処理したいといったケースです。Power Automate for desktopでは、「if」という条件分岐のアクションを使うことで、ファイルの拡張子を調べて、処理するファイルの種類を絞り込むことができます。これにより、誤った種類のファイルが処理されてしまうのを防ぐことができます。

最後に
Power Automate for desktopのクラウドコネクタを利用することで、WEB上のファイルもデスクトップフローの中で扱うことができます。
もっと良い方法があると思いますが、簡単に実装でき、今のところフローが安定して稼働しているのでとても助かっています。
クラウドフローで完結できるなら無理に使わなくても良いかと思いますが、市民開発者としては取れる手段が増えることで助けられることは多くあると思います。
簡単ですが、現場からは以上となります🤖