#はじめに
モダンデザインが登場したのが、v2020.10ですので1年以上経過したことになります。
なんとなく勉強し直すのが面倒くさくて放置していましたが、久しぶりにモダンデザインに変更してみると、なんとExcelアクティビティが大きく変わってました!社内外でも質問されることが増えてきたし、私自身Excelアクティビティは1番よく使うアクティビティなので、勉強しなきゃと思い、ようやく重い腰を上げました。
#つかうもの
今回の検証では以下の環境を使用します。
UiPath Studio 2021.10.4
- UiPath.Excel.Activities v2.11.4
#モダンデザインとは
モダンデザインとは、これまでのUiPath Studioのデザイン(モダンデザインに対してクラシックと呼ぶ)を一新し、新しいデザイン、アクティビティ、レコーディングなど提供するものです。クラシックとモダンの違いはかなりあるようで、正直、学習コストもそれなりにありそうな感じです。
##始め方
プロジェクト単位でモダンデザインを使う・使わないかを選べます。
プロジェクト設定の全般メニューからスイッチングできます。
##アクティビティの違い
モダンデザインに変更すると、今までない新しいアクティビティが増える一方、これまで表示されたいくつかのアクティビティ(例えば、要素の存在を確認など)が検索できなかったりするので、よく問い合わせをもらいます。これはアクティビティツリーのフィルターがかかっているだけなので、「クラシックアクティビティを表示」にチェックを入れれば、これまで通りクラシックアクティビティを使用することが可能です。
クラシックアクティビティは非推奨アクティビティとは別物なので、使っちゃいけないわけではないようです。基本、クラシックアクティビティはモダンアクティビティに移行されているようですが、クラシックアクティビティを使い続けたい方は使えばいいと思います(いづれ非推奨カテゴリに入る日が来るかもしれませんが、公式からはアナウンスされていません)。
##UIAutomationの違い
UIAutomationは、何やら大きく変わっているようです。
ちゃんと勉強してからにしたいので、今回は割愛しますが、複数の手段(普通のセレクター、あいまいセレクター、画像)によってUIAutomationを行うみたいです。これによって精度の向上や運用時のセレクター取り直しを防いでくれるようです。
#Excelアクティビティ
参考(UiPath公式ドキュメント)
##新しい(モダン)のExcelアクティビティ
すごい増えてますが、アクティビティの名前からどういったアクティビティなのかは何となく分かりますね。
セルの色を取得など一部クラシックのアクティビティが足りてないですが、業務で必要な大体のアクティビティは網羅されているようです。さらに、モダンの方がより実践で役立つアクティビティが充実している気がします。
どうやらStudioXのアクティビティを本家Studioへフィードバックした感じのようです。なので、操作性に関してはStudioXを触ったことがある方は馴染みやすいと思われます。
##クラシックアクティビティを使った実装
実際の業務でもよくあるExcelファイルから一覧を読み込み、1行ずつ処理するフローを作ってみます。
今までの実装では、「Excelアプリケーションスコープ」で読み取るExcelファイルを指定し、中に「範囲を読み取り」を置き、特定シート内のデータをDatatable型で取得します。次に「繰り返し(データテーブルの各行)」でDatatable型変数を1件ずつ処理します。
##モダンアクティビティを使った実装
まず、フローの大外を「Excelプロセススコープ」で囲い、その中に「Excelファイルを使用」を配置します。この2つのアクティビティは、クラシックでいう「Excelアプリケーションスコープ」と同じ役割です。
Excelプロセススコープのオプションを変更すると、様々な設定を変更することができます。プロジェクト設定で共通ポリシーを定めておけば、いちいちExcelプロセススコープ毎で設定をする必要はなく、設定漏れを防げるので品質は上がるかと思います。
次に「Excelファイルを使用」の中に「繰り返し(Excelの各行)」を置くことで1件ずつ処理できます。
繰り返しの対象範囲を指定する際、「+」のマークから[Excel]を選択することで楽に範囲選択が可能です。
また、以下のように読み取った列名が入力補完されるので、実装はかなり楽になるかと思います。
今回の例は、Datatable型変数を使わず実装した分、クラシックよりもシンプルになりましたが、読み取ったExcelデータはExcelプロセススコープ内でしか使えません。データを繰り返して使いたい場合もあるかと思うので、その場合は、「繰り返し(Excelの各行)」の代わりに今まで通りに「範囲を読み込み」を使ってDatatable型変数に取り込んだ方がいいです。
最後に細かいのですが、クラシックでは「Excelアプリケーションスコープ」の出力「ブック」に変数を指定すると、スコープ外でもExcelプロセスを保持したまま(Excelブックを開いたまま)にでき、任意のタイミングでブックを閉じることができました。ブックの競合を防ぐために敢えてこのような実装をすることもありました。
一方、モダンではできそうにありません。スコープを出るとExcelプロセスは消滅するので、ブックを開いている間のすべての処理はExcelプロセススコープ内に書くことになりそうです。階層が深くなり可読性が下がるかもしれないので、実装するときは意識したいところです。
##2つのExcelプロセススコープ
モダンのExcelプロセススコープは「Excelプロセススコープ」と「単一のExcelプロセススコープ」の2つあります。クラシックでは、「Excelアプリケーションスコープ」の1つしかなかったので、モダンではどちらのプロセススコープを使用するか迷うかもしれません。
###Excelプロセススコープ
機能的にはクラシックの「Excelアプリケーションスコープ」に相当するものみたいです。Excelウィンドウの可視、ファイル競合時のアクション、既存プロセスがあった場合のアクションなど、クラシックより細かく状況を設定できます。
「Excelファイルを使用」を抜けるとExcelブックが閉じられ(この時点ではExcelプロセスは生きたまま)、「Excelプロセススコープ」を抜けるとExcelプロセスがキルされる仕様のようです。
###単一のExcelプロセススコープ
起動できるExcelプロセスが1つとする制約があるようです。なので、ワークフロー実行時、既にExcelプロセスが立ち上がっている場合(Excelブックを開いている場合)、アラートのポップアップが出ます(ポップアップが出るということはAttendedで使用するアクティビティですね)。プロセスの多重起動をせず処理するので、PCのリソース的には「Excelプロセススコープ」より軽くなるはずです。「Excelプロセススコープ」のようなオプションの設定はできません。
#さいごに
今まで面倒くさくて避けていましたが、いざモダンデザインに変更してみると、Excelアクティビティは割と簡単でした。StudioXからのフィードバックのため、今までよりプログラミングの感覚が薄れ、直感的に実装できそうな感じです。
ただ、今までDataTableやDataRow型の変数を駆使してプログラミングに近いことをやってた方は、慣れるのに多少時間がかかるかもしれません(今まで使っていた.NETの式がそのまま使えないこともあります)。
※Excelアクティビティ以外のモダンデザインも至急キャッチアップしようと思いました