変数を使ってExcelからDataTableを取得する方法を紹介します。
変数を使ってExcelからDataTableを取得する
今回取得する予定のExcelデータはこちらです。
それでは、さっそくPADで[Excelの起動]アクションで、こちらのExcelを開いていきます。
ExcelからDataTableを取得するためには、[Excelワークシートから読み取る]アクションを利用するのですが、最終列や最終行をベタ書きしてしまうと行や列が追加された場合に毎回フローを編集しなければならず手間になります。
※べた書きした例↑↑↑
そのため、最終列と最終行をそれぞれ保持する変数を用意します。
変数作成のためには、[Excelワークシートから最初の空の列や行を取得]アクションを使用します。
実行すると、FirstFreeColumn
と、FirstFreeRow
という変数が自動生成されました!
値にはそれぞれ、"4"と"9"という数字が格納されています。
Excelを確認すると…、きちんと最初の空白の列番号と行番号が取得されていることが分かります。
変数の用意ができたので、[Excelワークシートから読み取る]アクションにセットしていきます。
{x}をクリックすると、既存の変数を選ぶことができます。
変数は%で囲って使用します。
変数FirstFreeColumn
と、FirstFreeRow
が-1されていることにお気づきでしょうか?
[Excelワークシートから読み取る]アクションを利用して取得したいセル範囲は、以下オレンジで囲った部分になるため、それぞれ-1をします。
ヘッダーカラム付きのExcelの場合、詳細>範囲の最初の行に列名が含まれていますをオンにしてあげるのを忘れないようにしましょう。
作成したフロー
こちらを実行すると、無事に変数を使用してExcelからDataTableを取得することができました!
注意点
[Excelワークシートから最初の空の列や行を取得]アクションを使用するにあたって、注意点が2点あります。
注意点①
当たり前ではありますが、以下のようなデータの場合、E列、10行目が最初の列、行として取得されます。意図しない範囲を取得しないように、Excelデータの値にはご注意ください。
注意点②
注意点①と通ずる部分がありますが、もう一点紹介させていただきます。
こちらのExcelは、先ほど無事取得したExcelと同じように見えますが…
DataTableの値もこの通り、最初の空の列と行が正しく取得出来ていなかったため、不要な列と行が入ってしまっています。
Excelの値を用意したら、念のため必要な範囲の周囲の列と行を削除しておく等の対策が良いかもしれません。
おわりに
読んでいただきありがとうございました!
お役に立てれば幸いです。