MS製RPAツールである「Power Automate Desktop」を触り始めましたが、「Excelシートを順番に処理するには、どうすれば良いの?」という疑問が出たので、記事として纏めてみました。
※以下は、関連記事となります。(良ければ参考にしてください)
前提について
今回紹介するアクション等、説明を最小限に絞っています。(色々書くと、何を伝えたいのか、がボヤける為)
色々、補足すべき事項があったりしますが、まずは、触ってみる事に重点を置く、で良いと考えています。
下準備
下準備として、以下のExcelファイルを作成したものと仮定します。
※補足として、C列「値」には数値、D列「値(文字)」は数値を文字として、E列「値(数式)」は数式(A列×C列+1)を入れています。
data:image/s3,"s3://crabby-images/407f7/407f7af3c9a58d209995144e6d57aa1293fb0de3" alt=""
上記ファイル「load_excel_file.xlsx」を、Dドライブ「D:\temp2」配下に置きます。
data:image/s3,"s3://crabby-images/83b89/83b8907d7b59dbecd4d21253b6322dd1916b4952" alt=""
まずの下準備は、これでOKです。
「Power Automate Desktop」の操作
ここでは、新規にフローを作成します。
名前は好きなもので良いです。
data:image/s3,"s3://crabby-images/ae4fb/ae4fb60a5b008519c2c70aa71bed34522853dfb0" alt=""
アクションの作成
data:image/s3,"s3://crabby-images/5a569/5a569810399ce1ac7c447d3ac4487bc9b6c8137c" alt=""
まずは、完成させたフローがありますので、それを元に説明を纏めています。
なお、今回のPower automateのアクション一式を、以下のコードに纏めました。
コードをコピーして「Power automate」に張り付ければ、アクション一式が追加されます。
※以降の手順が面倒な際は、ここでコピーして下さい。
Excel.LaunchAndOpen Path: $'''D:\\temp2\\load_excel_file.xlsx''' Visible: True ReadOnly: False LoadAddInsAndMacros: False Instance=> ExcelInstance
Excel.GetFirstFreeColumnRow Instance: ExcelInstance FirstFreeColumn=> FirstFreeColumn FirstFreeRow=> FirstFreeRow
LOOP LoopIndex FROM 2 TO FirstFreeRow - 1 STEP 1
Excel.ReadCells Instance: ExcelInstance StartColumn: 1 StartRow: LoopIndex EndColumn: FirstFreeRow EndRow: LoopIndex ReadAsText: False FirstLineIsHeader: False RangeValue=> ExcelData
Display.ShowMessage Title: $'''Excelファイルを上から順番に読み込むサンプル''' Message: $'''1列目:%ExcelData[0][0]%、
2列目:%ExcelData[0][1]%、
3列目:%ExcelData[0][2]%、
4列目:%ExcelData[0][3]%、
5列目:%ExcelData[0][4]%''' Icon: Display.Icon.None Buttons: Display.Buttons.OK DefaultButton: Display.DefaultButton.Button1 IsTopMost: False ButtonPressed=> ButtonPressed
END
Excel.Close Instance: ExcelInstance
data:image/s3,"s3://crabby-images/8f499/8f499981d7d0d3ab21e4e5dbf33ed5e58bd7514e" alt=""
data:image/s3,"s3://crabby-images/8822c/8822cf323a94d7e23725cc66ef9618556d356277" alt=""
Excelの起動
まずはExcelを開くアクションを追加します。
data:image/s3,"s3://crabby-images/83c58/83c5884e42d435647dc95f6fdb8d34b9de48f179" alt=""
左ツリーに「Excelの起動」があるので選択(ダブルクリック)します。
data:image/s3,"s3://crabby-images/54883/54883cfad09bfce20a263968fbfa77a776d8c1f0" alt=""
パラメータ選択で、以下の絵(赤枠)のように指定します。
※ここでは「下準備」で作成したExcelファイルを開いています。
data:image/s3,"s3://crabby-images/81f12/81f124ca4bc2731b3f2019e8dda50c104e0a351d" alt=""
Excelワークシートから最初の空の列や行を取得
data:image/s3,"s3://crabby-images/ce3b8/ce3b86fdf60ca2b669c837a20626fa94c2bde542" alt=""
ここでは、Excelシート内の最初の空列、空行を取得しています。
取得する理由ですが、単にExcelシート内の最終列、最終行を取得しています。
※以下の絵を参照。
data:image/s3,"s3://crabby-images/fa877/fa877b5b0b2811ce85af1875f2545249e11dd54e" alt=""
では、PowerAutomateの左ツリーから、先ほどの同様に「Excelワークシートから最初の空の列や行を取得」を選択してください。
data:image/s3,"s3://crabby-images/1b907/1b907aa34fc0f4063393f958156b080de311e176" alt=""
data:image/s3,"s3://crabby-images/168f2/168f2512e19666e9e72543d28a104f383c62be96" alt=""
本アクションは、そのまま「保存」してください。
(デフォルトで、変数「FirstFreeColumn」「FirstFreeRow」が生成されます)
ループを作成
次はループを作成します。(Excelシートを1行ごとに処理させるために作ります)
data:image/s3,"s3://crabby-images/00180/0018078539e1ba80f57906809c45c1ecf7180e96" alt=""
アクションに「Loop」があるので選択します。
data:image/s3,"s3://crabby-images/2ecc6/2ecc6e7999c4ad6bd851ee5de0fc6eec585e7c35" alt=""
パラメータを以下を指定します。(赤枠参照)
data:image/s3,"s3://crabby-images/b09ed/b09ed6434a9ecc2db269897d0a08253ae3378c3f" alt=""
data:image/s3,"s3://crabby-images/38c73/38c731954923da874f15e4fe6c2ab1b999d504d1" alt=""
Excelワークシートから読み込み
次はループ内のアクションを追加します。
data:image/s3,"s3://crabby-images/ed181/ed181728ba7db3d40756881ae6a9522eff5e8e93" alt=""
data:image/s3,"s3://crabby-images/af823/af8236240dfd779a888b94966e2d807fe648dcb2" alt=""
アクションに「Excelワークシートからの読み取り」があるので選択します。
data:image/s3,"s3://crabby-images/e4690/e4690fd58af0dd9311da602a731cde3a746d2927" alt=""
パラメータの補足ですが、「先頭行」と「最終行」に「%LoopIndex%」を指定してますが、これは、ループ内の変数(今、何行目を扱っているのか)になります。
ループは1行単位で処理する前提なので、1行分のみ読み込みます。(「先頭行」と「最終行」に同じ値を設定)
なお、このアクションで、変数「ExcelData」が生成されます。
この変数にExcelシートの情報が入っています。
メッセージを表示
次に、上で取得したExcelセルの内容を表示します。
data:image/s3,"s3://crabby-images/3940c/3940c40d5417c4c8b501fc3e6975c996a1a07ffe" alt=""
アクションに「メッセージの表示」があるので選択します。
data:image/s3,"s3://crabby-images/f067d/f067d897b39c84f9d9db904c936c1d5aaaa6e5c5" alt=""
data:image/s3,"s3://crabby-images/61ab9/61ab9f8d9ee9a766b5f1bfb008cb04d574c196f9" alt=""
「表示するメッセージ」に、上で生成された変数「ExcelData」を指定しています。
なお、変数「ExcelData」は2次元配列(行と列のリスト)で設定されているので、値を取り出す際に、何行目の何列目であるか、を指定しています。
※1行ずつ読み込んでいるので、行は0固定を指定(「ExcelData[0][0]~「ExcelData[0][4]」)しています。
ここまでで、ループ内のアクションは終わりです。
Excelを閉じる
最後に、開いているExcelファイルを閉じるアクションを追加します。
data:image/s3,"s3://crabby-images/b3b9a/b3b9a20de3001b895fd791b0620a2b320a43dc30" alt=""
data:image/s3,"s3://crabby-images/9ab04/9ab045679525216752098ad5467d58aacb82d842" alt=""
data:image/s3,"s3://crabby-images/b49db/b49db6fa3765f7c9ae898702aa95ed7c9900051b" alt=""
本アクションは、そのまま「保存」してください。
ここまでで、一通りのアクションの追加は終わりです。
お疲れさまでした!
実際に動かしてみる
では、作成したアクションを実際に動かしてみましょう。
data:image/s3,"s3://crabby-images/3495c/3495cf3de051c97d25855517e8c54dda21ae8ba1" alt=""
data:image/s3,"s3://crabby-images/87dcd/87dcdb02e13c2fc630ab5a97cbd905de075385a2" alt=""
メッセージにExcelシートの内容が表示されているかと思います。
(メッセージを閉じると、次の行のメッセージが表示され、最後まで表示すると、Excelを閉じて終了すると思います)
まとめ
今回は「Power Automate Desktop」でExcelシートを上から順に読み込むサンプルを作成しましたが、如何だったしょうか。
Excelファイルを1行ずつ読み込んで処理させる、というケースは多いかと思いますので、1つ雛形を作成して、それを使いまわすようにすると、ラクが出来るのかな、と感じています。
この内容が少しでも参考になれば幸いです。
コメント