Power AutomateにあるExcelのアクション「スクリプトの実行」がかなり便利そうだったので遊んでみた。
参考サイト
Excel Online限定のOffice スクリプトを使用してグラフを作成し、そのグラフを画像としてPower Automateでメール送信してみる。
Excelの準備
まずは参考サイトからサンプルExcel(email-chart-table.xlsx)をダウンロードし、
https://docs.microsoft.com/ja-jp/office/dev/scripts/resources/samples/email-images-chart-table#sample-excel-file
data:image/s3,"s3://crabby-images/6c807/6c8075dee8fcfa44c06802bbd9dfe1adc07d1fe0" alt=""
https://docs.microsoft.com/ja-jp/office/dev/scripts/resources/samples/email-images-chart-table#sample-excel-file
data:image/s3,"s3://crabby-images/6c807/6c8075dee8fcfa44c06802bbd9dfe1adc07d1fe0" alt=""
そのExcelをOneDriveとかSharePoint OnlineとかのExcel Onlineで使用できる場所にアップロードする。
data:image/s3,"s3://crabby-images/40034/400344cca5a9656a78b1cf926b4e83a3e0f9b78b" alt=""
data:image/s3,"s3://crabby-images/40034/400344cca5a9656a78b1cf926b4e83a3e0f9b78b" alt=""
そしたらそのファイルをExcel Onlineで開いて、[自動化]タブの[新しいスクリプト]を選択し、コードエディターを開く。
data:image/s3,"s3://crabby-images/5aa9a/5aa9a44d35eb0d01703f31bbf075a48316910402" alt=""
data:image/s3,"s3://crabby-images/5aa9a/5aa9a44d35eb0d01703f31bbf075a48316910402" alt=""
エディターの中に参考サイトのコードを入力して、スクリプト名をいい感じにつけてあげる。
https://docs.microsoft.com/ja-jp/office/dev/scripts/resources/samples/email-images-chart-table#sample-code-calculate-and-extract-excel-chart-and-table
data:image/s3,"s3://crabby-images/9f9b5/9f9b5c22f83aa6dace0251038e36d62e96af8901" alt=""
https://docs.microsoft.com/ja-jp/office/dev/scripts/resources/samples/email-images-chart-table#sample-code-calculate-and-extract-excel-chart-and-table
data:image/s3,"s3://crabby-images/9f9b5/9f9b5c22f83aa6dace0251038e36d62e96af8901" alt=""
スクリプトを保存したらExcel側の準備は完了!
data:image/s3,"s3://crabby-images/7412f/7412ffeeca2100346ed3e12f387fc5e9c117d504" alt=""
data:image/s3,"s3://crabby-images/7412f/7412ffeeca2100346ed3e12f387fc5e9c117d504" alt=""
Power Automate実装
そしたら適当なトリガーでPower Automateのフローを作成し、Excel Onlineの「スクリプトの実行」アクションを追加。
data:image/s3,"s3://crabby-images/714cf/714cf262825b85bf4cb4c6bba48b435e86cc891c" alt=""
data:image/s3,"s3://crabby-images/714cf/714cf262825b85bf4cb4c6bba48b435e86cc891c" alt=""
さっき作ったExcelとスクリプトを指定してあげる。
data:image/s3,"s3://crabby-images/75b18/75b189d59b6fcd76176218f3c0ee64429bca997b" alt=""
data:image/s3,"s3://crabby-images/75b18/75b189d59b6fcd76176218f3c0ee64429bca997b" alt=""
そしたらOutlookのメール送信アクションで参考サイトに書いてある本文を入力し、「スクリプトの実行」アクションからの戻り値を入れてあげる。
https://docs.microsoft.com/ja-jp/office/dev/scripts/resources/samples/email-images-chart-table#power-automate-flow-email-the-chart-and-table-images
data:image/s3,"s3://crabby-images/49785/497851f6e8c02931f82a5168262f0581b3bc1717" alt=""
https://docs.microsoft.com/ja-jp/office/dev/scripts/resources/samples/email-images-chart-table#power-automate-flow-email-the-chart-and-table-images
data:image/s3,"s3://crabby-images/49785/497851f6e8c02931f82a5168262f0581b3bc1717" alt=""
※スクリプトの戻り値はこんな感じ。
data:image/s3,"s3://crabby-images/488f6/488f69af5284751310ba4b95bd548ca80a2548df" alt=""
data:image/s3,"s3://crabby-images/488f6/488f69af5284751310ba4b95bd548ca80a2548df" alt=""
実行
そしたらこのフローを実行してみると、
data:image/s3,"s3://crabby-images/24da1/24da1a9a8f9535f1cebd9751b1de4741270a5c8f" alt=""
data:image/s3,"s3://crabby-images/24da1/24da1a9a8f9535f1cebd9751b1de4741270a5c8f" alt=""
メールが届いてこんな感じでTypeScriptで作成したグラフが画像として送られてくる!
data:image/s3,"s3://crabby-images/fed3c/fed3c7736f468e3fcf1086f80b3cde5bfea495c1" alt=""
data:image/s3,"s3://crabby-images/fed3c/fed3c7736f468e3fcf1086f80b3cde5bfea495c1" alt=""
もちろんTypeScriptの方のコードを修正すると、
data:image/s3,"s3://crabby-images/39564/395647e9c9663dacc94c6ca400b724e9a075516f" alt=""
data:image/s3,"s3://crabby-images/39564/395647e9c9663dacc94c6ca400b724e9a075516f" alt=""
こんな感じで作成/送信するグラフを変えることもできる!
data:image/s3,"s3://crabby-images/8bb2c/8bb2cdc24a2ad55971b4d6fe4e07f78d1fa48bc2" alt=""
data:image/s3,"s3://crabby-images/8bb2c/8bb2cdc24a2ad55971b4d6fe4e07f78d1fa48bc2" alt=""
Power AutomateとExcelでできることってかなり限られているイメージだったけど、この「スクリプトの実行」アクションを活用することで色んなことができそうな予感!
コメント