14
9

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

Power Automate で Microsoft Forms の回答の添付ファイルのリンクを取得する

Last updated at Posted at 2024-01-21

はじめに

Power Automate では、Microsoft Forms で回答があったことをトリガーにアクションを起こすことが出来ます。

例えば、以下のように、回答内容を SharePoint リストに登録したり、通知をしたりする自動化フローを簡単に作れます。

image.png

そして、Microsoft Forms から何かの問い合わせを受ける際など、添付ファイルを受け付けることがあると思います。

image.png

そして、以下の勉強会で質問があがりましたが、この添付ファイルを扱う際、少し工夫がいります。そのため、今回、アプローチを簡単に紹介します。

アプローチ

困ること

まず、Forms からアップロードされた添付ファイルの項目、こんな感じで文字列になっています。

image.png

[{"name":"Sales9-11_益森 貴士.xlsx","link":"https://******.sharepoint.com/personal/******/_layouts/15/Doc.aspx?sourcedoc=%7BD547C649-15E9-4136-B826-C6BA1AE7B1EA%7D&file=Sales9-11_%E7%9B%8A%E6%A3%AE%20%E8%B2%B4%E5%A3%AB.xlsx&action=default&mobileredirect=true","id":"01LKYYNBSJYZD5L2IVGZA3QJWGXINOPMPK","type":null,"size":12070,"referenceId":"01LKYYNBRPNYUSZ67NGBCJOZM7KGAG25OS","driveId":"b!i9dg-Fi5hUeKtyCVpL82y85rO-v-AehDprSL7HS5H27W7PBmAYPDS6oK2BoAIUqD","status":1,"uploadSessionUrl":null}]

そのため、こちらの項目を以下のようにして動的な値として利用しても、文字列として代入されるため、リンクをクリックしてそのままアクセスすることは出来ません。

image.png

したがいまして、多くの人は、この文字列の中から、link だけを取り出したいと思います。

解決方法

いくつか解決方法があるのですが、今回は気ままに勉強会中参加中に思いついたものを紹介します。

まず、上記の文字列、JSON 形式となっていることが分かります。ただ、Power Automate が文字列として認識しているようなので、link だけを抽出できないようです。

JSON について、ChatGPT に聞いてみました。要は、システム間でデータのやり取りをする際におけるルールが定義されているフォーマットの一つです。利用するだけの場合あまり意識しませんが、こうったフォーマットがあるおかげで異なるシステム間で連携ができるということです。

image.png

Power Automate もデータのやり取りは JSON でやっております。具体的には、コネクタを利用している際、JSON でやり取りをしております。

Power Automate の素晴らしいところは、例えば、以下のように、JSON で受け取った応答を解釈して加工をしてくれて、動的な値として画面上の操作だけで後続のアクションで利用できるようにしてくれているところです。

ある意味、このようにして、JSON について意識しなくても簡単な自動化フローを作れるため、上手く解釈出来ていない際に躓いてしまう可能性があるのかもしれませんね。

image.png

image.png

今回は、Forms の応答の添付ファイルに関する項目については、文字列として認識しているため、以下のように、json 関数というものを使って、Power Automate で JSON として処理してもらうようにします。

image.png

Power Automate が JSON として解釈してしまえば、[JSON の解析] アクションを介すことで、動的な値として利用することが出来ます。

個人的には、JSON 形式になっているのに Power Automate が文字列として解釈しており、中の項目を動的な値として利用したい際は、私はよく、一度 json 関数で囲ってあげています。

[JSON の解析] アクションのスキーマについては、一度ここまでの段階で処理を実行させて、作成アクションの出力をサンプルとして利用する感じです。これにより、後続のアクションにて、[JSON の解析] アクションの応答から、link だけを取得することが可能になります。

image.png

image.png

image.png

まとめ

今回は、Power Automate で Microsoft Forms の回答の添付ファイルのリンクを取得する方法を紹介しました。

他にもアプローチありますが、一つのアプローチとして参考になれば幸いです。

14
9
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
14
9

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?