はじめに
業務でBizRoboを触ったので、その特徴について気づいたところのメモ。RPAではほかにUiPathを触ったことがあるので、それと比較した点もいくつかある。
前提条件
v10.2 と v10.4
BizRoboの特徴
WebブラウザとExcel操作機能を内包
BizRoboは独自のブラウザを内包しているため、Webサイトの自動化はBizRobo内で完結する。
また、Excel読取&書込み機能も有しているため、PCにExcelがインストールされていなくてもExcelファイルを編集できる。
ただし、Excel周りの機能は「Apache POI」で実装されているため、完全に対応しているとは言いづらい。
Webブラウザの自動化に向いている
ブラウザをメモリ上で持つため、複数ロボットを実行しても動作に影響を与えない(パフォーマンス以外では)。
開発中もステップは実行される
Design Studioでは、ステップをクリックして選択すると、その1つ手前までステップが実行される。
Webサイトの参照などであれば致命的な問題とならないが、データの登録などを含む場合でも実行されてしまうので注意が必要。ただし、ファイル出力など一部のステップは編集時に実行しない設定になっている。
ステップを実行させずに選択するときは、Ctrl + クリック するか、右クリック→Select を選ぶ。
手順の多いロボットだと、ステップを選択するたびにいちいち最初から実行が走り、編集の妨げになることもある。
Desiginモードと値判定(Test Value)の挙動
ロボットを作っているときでも、フローの途中にある値判定(Test Value)ステップは実行される。しかも、判定がfalseになる場合、Error Handling等の設定がどうなっていてもそのステップでフローの実行が止まる。こうなるとWebサイトの自動化を作るときに下の画面で次はどこをクリックする…などの指定ができなくなる。
そのため、ロボットを開発する際は、条件分岐などは考えずにクリックなどのステップを作成し、そのあとに条件分岐などを追加していくとよいと思う。
デスクトップの自動化には向いていない
※v10.2で再現
ロボットに Desktop Automation ステップを追加するだけで、Design Studio の挙動が実用に耐えづらいほど遅くなる。
それに、機能が乏しい。例えば、UiPathにはある「テキストボックスを入力前に空にする」機能がない。繰り返し同じ項目に値を入力する場合、テキストボックスをクリアするステップを自力で実装する必要がある。
デスクトップの自動化にはPCが2台必要
※v10.4から、開発用にローカルDAが追加されたので、1台のPCでDAの開発ができるようになった。
Local Desktop Automationの機能と設定方法について – BizRobo! ナレッジベース
例えばUiPathはUiPath StudioがインストールされたPC単体で開発と実行が可能だが、BizRoboは開発用と実行用の2台が必要。ただし、WebサイトからファイルをダウンロードするなどBizRobo内で完結する操作であれば、DAは必要ない。
ブラウザの機能が十分とは言いづらい
例えば最近流行りの画像の遅延読み込みに対応していない。
ブランチと実行順序
別記事へ記載
【BizRobo】ブランチの特徴 - Qiita
条件分岐
値判定などの判定ステップで、指定した条件を満たさなかったときに「後続の処理をスキップ」すると、後続のステップすべてが無視される。
一般的なif&elseを実装したい場合、トライと値判定(などの判定ステップ)を組み合わせると良いと思う。
繰り返し処理
For Each
大体のケースでは、For Eachから始まる各種ステップを使用する。
気を付ける点としては2点ある。
・ループ範囲はFor Eachステップ以降すべてとなる。ループが終わった後の処理は、ループ手前でブランチを分けて実装する。
・変数およびブラウザの状態はループを抜けるとリセットされる(変数はグローバルにした場合は例外)。連続データを検索し、見つけたらループを抜ける…という処理をしたい場合は頭をひねる必要がある。
Webサイトの自動化
前述したとおり、BizRobo内部のブラウザ上で動作する。
ブラウザの種類
2種類のブラウザが用意されている。「デフォルト」と「クラシック」で、基本は「デフォルト」を使用する。社内システムなど、古いブラウザにしか対応していないようなWebサイトの場合、「デフォルト」ではうまく動かない場合があるので、そのときは「クラシック」を使用する。1つのロボットにつき、選択できるブラウザは1種類である。
TLS1.2を使用する
ヤフーなど一般的なWebサイトを利用する場合、URLが「https」で始まっている場合が多い。「SSL/TLS」という、通信の暗号化などにかかわるプロトコルだが、BizRoboの初期設定ではこのプロトコルのバージョンが低い。この状態でWebサイトを開こうとしても、エラーになってしまう。
その場合、ロボットの設定で使用するTLSのバージョンの変更が必要。
参考:サイトの SSL/TLS のバージョンが変わってしまい、サイトを Load Page(ページ読込)できなくなった場合のエラーと対処 – BizRobo! ナレッジベース
認証情報の設定
ユーザー認証が必要なWebサイトの場合、ロボットの設定で認証情報を指定する。
ロボットを開いた状態で設定のアイコンをクリックし、デフォルトオプションから「クレデンシャル」を設定する。
この辺の設定は「クリック」ステップ等で個別に設定することもできる。ただステップ1つずつこの設定をするのは大変なので、ロボットの既定値として設定しておくとよい。
タグファインダーに注意する
クリックなどのステップを作成した際、タグを見つけるためのタグファインダーは一度確認しておくとよい。
「タグパス」はタグの位置を示しているが、設定値によってはWebサイトのレイアウトが少し変わるだけで、目的のタグを見つけられなくなってしまう。
参考:DSのファインダーのタグ パス – BizRobo! ナレッジベース
上記サンプルではタグパスが.*.div.div.div.div.div.div.div.*.div.div.a
となっているので、「次へ」リンクまでのタグの構成が少しでも変わると「次へ」リンクを見つけられなくなってしまう。それを回避するために、.*.a
へ変更したほうが、Webサイトのレイアウトが多少変化しても「次へ」リンクを見つけやすくなる。
名前付きタグを活用する
Webページ全体から「次へ」リンクを探すのは嫌なので、リンクを探す範囲を限定したい…という場合、名前付きタグを活用するとよい。
ある範囲に名前付きタグを設定すると、それ以降のステップでその名前付きタグをタグファインダーに使用できる。
「ファインダー」タブの「検索範囲」を「名前付きタグで」へ変更し、その下の「このタグ内」で名前付きタグの名前を選択する。
名前付きタグは既定では自動的に命名され、1から順番に数字がつけられていく。
名前付きタグを扱う際には注意点がある。
それは、名前付きタグの指定はDesign Studio右側のエリアからでないと参照できない点である。ステップの設定ウィンドウを開いて名前付きタグを選ぼうとしても、選択肢に出てこない。
Excel読み書きの仕組み
Apache POI で実装しているらしく、POIが対応していない機能にはBizRoboも対応していない。