【どうしても煩雑になりがちなファイルの管理をPower Appsで行いましょう!】
今回の記事では、Power AppsからSharepointサイトのドキュメントにファイルをアップロードするアプリを作成します
data:image/s3,"s3://crabby-images/eeec7/eeec788fd1a6d9951957dd153a32dfcfa927f69c" alt=""
このアプリを使用することで、ファイルの保存場所を管理しやすくなります
また、手間なファイルのアップロードの処理を簡略化できます
アプリ作成はそんなに手間暇かかりません
ただし注意点がが幾つかあります
記事の中でそちらについては明記してありますので、都度ご確認の程よろしくお願いします
目次
ポイント
今回のアプリはPower Automateのフローと連携します
添付ファイルの内容をPower AppsからPower Automateフローに渡します
Power Automateフローでは、Power Appsから受けとった添付ファイルの内容を基にして指定Sharepointサイトのドキュメントにファイルを作成します
このファイルの受け渡し方が少々、とっつきにくいです
ファイルを添付する仕組みの作成~Power Apps~
最初にPower Appsでスクリーンを2つ用意します
そのうちの1つのスクリーンでフォームを作成します
data:image/s3,"s3://crabby-images/b7759/b77595e99d8a06aab8402b838baad853a4c14346" alt=""
フォームのデータソースは何でも構いません
欲しいのは「添付ファイル」のパーツです
data:image/s3,"s3://crabby-images/6998c/6998cd285f0ea91328ff813adafaa93580561d15" alt=""
下の画像のパーツを切り取り、別のスクリーンに貼ります
data:image/s3,"s3://crabby-images/a141c/a141ccd01b2d5ea149d8ef9ccab1c027df27e447" alt=""
別のスクリーンにパーツを貼り付けた後は、元のスクリーンは削除しましょう
次に貼り付けたパーツのプロパティを以下のように設定します
data:image/s3,"s3://crabby-images/07adf/07adf9a0083ed49beb10701e460e0b853a958d34" alt=""
・Items ⇒Blank()
・DisplayMode ⇒DisplayMode.Edit ・MaxAttachments ⇒1
*パーツには扱いやすい名前を付けましょう!
data:image/s3,"s3://crabby-images/3d0ef/3d0ef412b97ab922a5107004682e874d6bdef012" alt=""
ファイル作成をするフローの作成~Power Automate~
data:image/s3,"s3://crabby-images/76519/765190e93cd9d0add28ee959902c473f2eaac497" alt=""
トリガー
ここからPower Automateフローを作成します
トリガーはPower Appsからファイルの中身を受け取れるように「ファイルコンテンツ」を指定します
data:image/s3,"s3://crabby-images/a1998/a1998ee04972f8902f9a5c96a04db96d165d7a92" alt=""
ここで重要な注意点があります
data:image/s3,"s3://crabby-images/3d7c6/3d7c62ef2880500ba681cad475b971c5b7a9a617" alt=""
必ず3点リーダーから「フィールドを必須にします」を指定しておきます
data:image/s3,"s3://crabby-images/2a2dc/2a2dcfa5c4bd1bb5b0509e1c73595009e9f264da" alt=""
この設定が抜けるとうまく行きませんので確実に指定しましょう!
ファイル作成
次にファイル作成アクションを作成します
サイトのアドレスとフォルダーのパスには、ファイルの保管先を指定します
問題は次からです
data:image/s3,"s3://crabby-images/975c7/975c7d35ae5f22ac730fb3a63d0670bd0b3ae782" alt=""
まずファイル名です
data:image/s3,"s3://crabby-images/96210/96210cf59c6660f59893b75adebb500822ef6cec" alt=""
こちらはそのまま以下をコピーしてください
triggerBody()[‘file’][‘name’]
コピー先は下の画像の「式」の箇所ですので、間違いがないように注意をお願いします
data:image/s3,"s3://crabby-images/650d8/650d8dc80f7a8054b1b524d5162a884c019a0bf7" alt=""
コピー後は下のOKボタンを押します
すると以下のようになります
data:image/s3,"s3://crabby-images/735bf/735bf918c849ef0736b51caf874d00d350bc3918" alt=""
OKボタンを押した瞬間は上の画像のように、ファイル名が関数の表示になっています
こちらはフローを実行後は表示が変わるようになっています
data:image/s3,"s3://crabby-images/96210/96210cf59c6660f59893b75adebb500822ef6cec" alt="画像に alt 属性が指定されていません。ファイル名: image-34.png"
最後にファイルコンテンツを指定します
こちらはトリガーで受け取った内容を動的コンテンツから指定します
data:image/s3,"s3://crabby-images/41bd2/41bd23d8da1530e4feadce5dcdbe4c4cfc74827c" alt=""
仕上げ~Power Apps~
それでは最後にPower Appsを仕上げます
Power Automateフローを動かすボタンを作成します
こちらのボタンでは、Power Automateフローに添付ファイルの内容を渡せるようにします
添付ファイルの内容は2つあります
こちらの2つの内容の渡し方が少し癖があります
下のように{}を使用します
UploadFile_Ver1.Run(
{
①contentBytes:First( AttachmentFile.Attachments).Value,
②name:First( AttachmentFile.Attachments).Name
}
)
上記の①②の中身ですが、下の画像の名前を使用します
data:image/s3,"s3://crabby-images/246ae/246ae7ffcd8c44430219f28507cd3202a02281db" alt=""
①contentBytes:First( AttachmentFile.Attachments).Value
②name:First( AttachmentFile.Attachments).Name
こちらの内容については、上記の内容をそのままコピーし、パーツ名だけを変更することをおすすめします
これで指定した箇所に、Power Appsを通じてファイルを保管できるようになります
data:image/s3,"s3://crabby-images/b7ca9/b7ca913b3b8c63d7d228cf6d06451b68b554cb06" alt=""
<まとめ>
今回はPower Appsを通じてファイルを指定箇所にアップロードできるようにしました
そんなにアプリ作成には時間がかからないはずですが、何点か注意点があります
・Power Automate ⇒トリガーで必ず「必須」を指定する
・Power Automate ⇒ファイル作成アクションでファイル名を記事のコピーで作成する
・Power Apps ⇒Power Automateにファイル内容を渡す際、{}を使用して2つ引数を指定する
そのままアップロードしたエクセルファイルの内容をPower Apps内で使用する場合には、テーブルを事前に作成しておけば大丈夫です!
これでファイルの管理も楽になります
コメントを残す