この記事はUiPath AdventCalender6日目の記事です。みんなで盛り上がりましょう!!!
https://qiita.com/advent-calendar/2021/uipath
注意
今回の解説で使用するのはCommunity Licence(コミュニティ版)です。
またUiPathのバージョンは2021.10.3で説明しています。
アクティビティの表記の一部はアクティビティのバージョンにより微妙に表記が異なることもありますのでご承知おきください。
あらすじ
複数のデータテーブルに情報を格納して、それらを使って次の処理へ...という感じでデータテーブルを使い回してみたい。データテーブルを順番に回す方法ってあるのでしょうか???
さおは調べてみた。
データテーブルを順番に処理する方法
いろいろ探っていたら「これはいいかも」と思ったので、ざっくりでまずはフローを構築。
(今回は実験的な意味なのでフローはざっくりですが、普段はもっと丁寧に定義して作りますよ!)
上記のフロー図から2つのデータテーブル変数「sss」と「ttt」をそれぞれ作って値を突っ込んでみて、sss→tttの順で回してみましょう。(テーブル内の値は適当です)
Datatable変数:sss
この後、2つのデータテーブル変数に格納されているrow(0)にあたるColumn1の値にはそれぞれ「長野県」、「福岡県」と「大分県」、「東京都」という値が格納されています。
順番に「長野県」→「福岡県」→「大分県」→「東京都」と取得できるのか試してみましょう。
1.リスト型の変数を定義する
リスト型の変数を以下のように作成します。(変数の名前はわかりやすいものにしましょう)
変数はリスト型で設定します。この時の変数の定義はデータテーブル型の変数にします。
※Variable type(変数)にないときは、「Browse for Types...」からリスト型を探してみよう。
2.コレクションに追加する
次にAddToCollectionアクティビティ(コレクションに追加)を2つ用意し変数を格納します。
【1つ目のデータテーブル】
Collection:LisAAA(1.で生成した変数)
item :sss
TypeArgument:Datatable
【2つ目のデータテーブル】
Collection:LisAAA(1.で生成した変数)
item :ttt
TypeArgument:Datatable
3.リスト型の変数を使って繰り返し回してみよう
【ForEach(繰り返し)アクティビティ】
プロパティは以下のように設定します。
TypeArgument:Datatable
Values:LisAAA
【ForEachRow(繰り返し(データ テーブルの各行))アクティビティ】
For Each側:CurrentRow(デフォルト)
※古めのバージョンでは「row」になっています。
In:item(この時"item"にはデータテーブル変数のsssとtttがリストで入っています。)
できたので実行してみましょう!
すると、row(0)で指定したColumn1の値がデータテーブル変数sss→tttの順で出てきました!
「長野県」→「福岡県」→「大分県」→「東京都」の順で出ていますね♪
(データテーブル変数sssの処理が終わると、データテーブル変数tttへ処理が進むようになります。)
ポイント
データテーブルをエクセルのように扱えるようになれば、今後はデータテーブルの活用範囲も広がるかもしれません!
今回はリスト型を使ってデータテーブルの順番を定義して処理してみましたが、今後もこういった疑問に対して調査や検証をしていこうと思います!