概要
OSの更新プログラム適用により、時としていままで動いていたRPAロボットの修正が求められることがあります。Windows 7 から Windows 10 のアップグレードくらい大きな変更ではない場合、物事をざっくり把握できる人間にとっては、あまり大した変更ではないことも、少しの仕様変更でも細かく指示を出さないといけないRPAロボットにとっては致命的な変更になることがあります。
2019年5月下旬に配信が始まったWindows 10 May 2019 Update バージョン1903 上 (以下、バージョン1903)では、徐々に対象マシンを広げながらアップデートされるマシンが広がってきています。私も自宅に3台あるWindowsマシンも2019年8月現在、ようやく2台目が対象に入りアップデートを行いました。バージョン1903では、さまざまな新機能が一覧されていますが、このほかにも細かい変更がたくさん行われています。
バージョン1903からメモ帳のコンテンツ変更でウィンドウタイトルにマーク(*)がつくようになった
RPAロボットに地味に影響がありそうな仕様変更として、メモ帳の仕様変更があります。メモ帳はバージョン1903から、テキスト変更後にウィンドウタイトルにアスタリスク(*)がつくようになりました。これにより、メモ帳をRPA運用環境で利用しておりコンテンツの変更を行うロボットは修正を迫られる可能性があります。Automation Anywhere の本体付属のサンプルでは、ロボットが途中で止まってしまう問題が発生しました。
テキスト変更後 ("無題"の前にアスタリスク (*) が追加される)
ロボットの修正
ウィンドウタイトルのテキストをマッチングして処理対象のウィンドウを判別している場合に問題が発生します。修正方法としては、このマッチングの条件に、ウィンドウタイトルのテキスト冒頭にアスタリスクが来てもよいように変更を加えることになります。WinActor、UiPath、Automation AnywhereといったRPAソフトウェアで具体的にどう修正すればいいのかを見てみましょう。(その他のソフトウェアも基本的に同じ考え方で修正すればOKなはずです)
サンプルとして、メモ帳を起動し、テキストを2行入力するRPAロボットを想定します。
WinActor
WinActorで作成したフローチャートでは、フローチャート画面の上の「ウィンドウ識別ルール」を使ってウィンドウの識別ロジックを確認できます。
WinActorではウィンドウの識別方法として「ウィンドウタイトル」「ウィンドウクラス名」「プロセス名」「ウィンドウサイズ」といった4通りの方法を利用できます。
ウィンドウタイトルで識別している場合は、「指定しない」にするか、「を含む」「で終わる」を指定すると、今回の仕様変更の影響をクリアできます。
UiPath
通常一番簡単な方法で作成するシーケンスだと以下のようになるかと思います。この場合、ウィンドウの識別は内部的にウィンドウ変数 (or 専門的な言い方だとウィンドウハンドル)で行われているようなので、バージョン1903のようにタイトルの先頭にアスタリスクがついても動作に影響はないようです。
ただし、「ウィンドウにアタッチ (Attach Window)」の処理が入っている場合、ウィンドウを何で識別させているかで影響の有無が変わってきます。
UiPathではウィンドウの識別方法として「ウィンドウ変数」「ウィンドウクラス名」「プロセス名」「ウィンドウタイトル」といった4通りの方法を利用できます。
以下のように、ウィンドウ (=ウィンドウ変数)でなくセレクターで選択されている場合、ウィンドウタイトルでの識別になるため、この文字列は変更する必要があります。
変更前
"<wnd app='notepad.exe' cls='Notepad' title='無題 - メモ帳' />"
一番簡単な方法は、タイトルでのマッチを消してしまうことです。こうすると、UiPathはプロセス名などほかの方法だけでマッチングを行います。
変更後
"<wnd app='notepad.exe' cls='Notepad' />"
Automation Anywhere
Automation Anywhere では、ウィンドウを識別する唯一の方法は「ウィンドウタイトル」になっているので、WinActorやUiPathよりも深刻です。
各コマンドでウィンドウタイトルを参照しているところ ($WindowTitle$
、3行目でActive Window Title をこの変数に格納している)について、前方にワイルドカード (*) をつけて、アスタリスクがあってもなくても該当ウィンドウを捕捉できるようにすればOKです。(ちなみに、ここでは追加される文字がたまたまアスタリスクですが、今回追加するワイルドカードとたまたま文字が一致しているだけで、意味は違います。)
修正点
4/5行目のウィンドウタイトルの参照
- 修正前:
$WindowTitle$
- 修正後:
*$WindowTitle$