ファイル・フォルダーの種類
Main.xamlファイル・・自動化処理の流れを定義したワークフロー ファイル project.jsonファイル・・プロジェクト固有の情報が定義されているファイル .screenshotsフォルダ・・ワークフローを UiPath Studio で開いた際に表示される、参考スクリーンショットの画像ファイルが格納されるフォルダアクティビティ
アクティビティ・・処理を自動化する最小の部品フローチャートとシーケンス
フローチャート・・条件分岐、前の処理に戻るなどより複雑な処理を行うワークフロー シーケンス・・一直線に処理を行うワークフロー変数
・[変数 (Variables)] パネルから変数名を変更した場合、ワークフロー上で使用されている同じ名前の変数は一括で変更される ・変数の予測変換は、「Ctrl + スペース」データ型
Array型
中の要素:編集可能 構成する要素の数:編集不可List型
中の要素:編集可能 構成する要素の数:編集可能制御フロー(制御構造)
順次構造
上から下へ処理が順次実行される構造分岐構造
判断条件を元に処理を分岐させて実行させる構造フロー条件分岐(Flow Decision)
フローチャート上で使用。 分岐条件を設定し、条件を満たす時は [True] の先の処理を実行し、 条件を満たさない時は [False] の先の処理を実行。 条件により、全く異なる処理を 2 種類作成する際など、大きな違いがある場合は、フローで分岐させる。条件分岐(If)
シーケンス上で使用。 [条件分岐 (If)] はシーケンスの中で使用します 分岐条件を指定し、条件を満たしたときは、[Then] の中の処理を実行し、条件を満たさないときは、[Else] の中の処理を実行。※[条件分岐 (If)] の中に、[条件分岐 (If)] を設置すると、ワークフローの可読性が低くなるから避けよう。
反復構造(ループ)
繰り返し作業の自動化に頻繁に使用される制御構造[フローチャート (Flowchart)] を使用する方法
[繰り返し(前判定) (While)]
条件を満たしている場合に Body 内に格納されているアクティビティが繰り返し実行される[繰り返し(後判定) (Do While)]
条件に関わらず Body 内に格納されているアクティビティが一度実行されます その後、条件を満たしている場合、Body 内のアクティビティが繰り返し実行される[繰り返し (コレクションの各要素) (For Each)]
リストや配列などコレクションで指定したデータの型の各要素に対して、1つずつ [本体 (Body)] 内に格納されている処理を、繰り返し行うことができる[繰り返し (各行) (For Each Row)]
Data Table 型データの各行に対して、Body内に格納されている処理を、繰り返し行うことができるGenericValue 型
テキスト (String) / 数値 (Int32) / 日付 (Date) / 配列 (Array) / 真偽 (Boolean) など、あらゆる種類のデータを格納できる変数の 1 つで、UiPath Studio 独自の変数の型連結
2 つの GenericValue 型変数を連結しようとした場合、式の最初の変数が文字列として定義されている場合には、結果は 2つ文字列の連結になるが、整数として定義されている場合の結果は、それらの数値合計になるExcel
Excel を操作する 2 種類のアクティビティ
[アプリの連携 (App Integration)] >[Excel] カテゴリに属するアクティビティの利用
多数の行と列にまたがるExcelデータを取り扱う場合や、様々なExcel操作を安定的に自動化する場合に使う。 [Excelアプリケーションスコープ(Excel Application Scope)] 内に配置。※Excelアプリケーションスコープ・・指定したMicrosoft Excelワークブックを開き、内部に配置したアクティビティを [実行] して処理が完了すると、ワークブックとExcel を終了
[システム ]>[ファイル] >[ワークブック] カテゴリに属するアクティビティの利用
Microsoft Excel がインストールされていない環境でも使用できるが、アクティビティ毎に対象のExcelファイルを指定する必要がある。メソッド
文字列型 toString containsdataRow[]、dataTable型などの値の取り出し方
ex)
要素名("カラム名")
コレクションの変数名.Rows(Rowのindex)("カラム名")
メソッド
コレクションの変数名.Select("カラム名 = 値 and カラム名 = 値")
レコーディング
自動レコーディングできるもの
文字入力 左クリック チェックボックス ドロップダウン など手動レコーディングするもの
ショートカットキー 修飾キー(Ctrl + C, Ctrl + A)など 右クリック マウスオーバー などショートカット
esc・・レコーディングを止める、再度押すと保存&終了する F2・・レコーディングを一定時間停止ユーザーインターフェイスとセレクター
ユーザーインターフェイス
ウェブページをはじめとしたアプリケーションのユーザーインターフェイスは、入れ子状のコンテナーに格納された要素で構成されているセレクター
ユーザーインターフェイス内の特定のアクションを自動化するために、これらのコンテナーや要素の属性を使用し、指定した要素までの住所のようなものを自動生成したもの。アクティビティ(ex.クリック、文字を入力)が生成する。 ※アクティビティの [プロパティ (Properties)] パネル > [入力 (Input)] > [ターゲット (Target)] > [セレクター (Selector)] > … をクリック→[セレクターエディター (Selector Editor)] が開き確認できる OR ワークフロー内に配置されているアクティビティのオプションボタンをクリック→[セレクターを編集 (Edit Selector)] をクリック→[セレクターエディター (Selector Editor)] が開き確認できるUI Explorerとセレクターエディター (Selector Editor)
UI Explorer
特定のUI要素の構造を確認したり、独自のセレクターを作成できるツールセレクトエディタ
UI Explorerの簡易バージョンであり、設定されているセレクターの内容確認と部分的な編集することができる完全セレクターと部分セレクター
完全セレクター
最上位ウィンドウ (アプリケーション) の要素を含み、UI 要素の特定に必要な全ての要素を含むセレクター ベーシックレコーディングで生成。部分セレクター
最上位ウィンドウ (アプリケーション) の要素を含まず、[ウィンドウにアタッチ (Attach Window)]・[アプリケーションを開く (Open Application)] などのコンテナーのセレクターと合わせて機能するセレクター デスクトップやwebレコーディングなどで生成。安定的なセレクターの作成方法
要素が変更する可能性がある場合に使用する、ワイルドカード
操作対象ファイルを例とした場合、ファイル名が変更される、ファイル名がシステムにより自動的に生成される、またはファイルの正確な名前が分からない等、要素が変更する可能性がある場合は、セレクターの調整が必要 *・・文字数に制限なく置き換える ?・・1文字のみ置き換える ※この場合、セレクターエディターの [修復 (Repair)] 機能も活用できるidx を使用するセレクターの場合は、他の属性を追加する
インデックス (idx) 属性とはUI要素を 1番目の要素、2番目などの要素を、番号で指定する属性であり、選択した要素に固有の情報がない場合、セレクター上に自動的に生成される。 将来的にUI要素の順番が変動する可能性があるため、できるだけ使用は避け、他の属性を追加しよう。属性値、またはセレクター全体を変数に置き換える
例えば、ユーザーが入力した任意の数字に対応し電卓をハイライトさせる場合、入力される数字によりセレクターが異なる場合、セレクターの調整が必要ex)※変数Numberは入力ダイアログで入力した値
< uia automationid='num0Button' >
→< uia automationid='num" + Number + "Button' >
OR
セレクタ全体
→変数NumberSelector
セレクター欄をNumberSelector.Replace("0", Number.toString)に変更
複雑なアプリケーション上のセレクター調整
ページを更新するごとに要素の位置やセレクターの値が変化する場合、、アンカーベース (Anchor Base)
近くにある固定的な要素(ラベルやアイコンなど)を目印にすることで、変更される可能性のある要素を指定できるアクティビティであり、アンカー(要素を探す、画像を探す)とアクティビティをセットで格納できるコンテナー相対セレクター
アンカーベースは常にアンカーの画面上の位置を使用するため、バックグランドでは要素を指定できない可能性がある。 そこで、UI Explorerの[アンカーを選択]を使用し、アンカーに設定したUI要素と目的とするUI要素の相対的な位置をnavタグで指定することで、安定的なセレクターを作成する子要素を探す(Find Children)アクティビティ
指定した範囲とフィルター条件に従って、子や孫のUI要素のコレクションを取得するex)[子要素を探す]で入力フィールドを含む親要素を指定し、その子要素のコレクションを取得する
繰り返し(コレクションの各要素)内↓
・
・
条件分岐
要素名.GetFriendlyName.Contains("input")
Thenなら・・
Elseなら・・
例外
アプリケーション例外とビジネス例外
アプリケーション例外(アプリケーションエラー)
システム障害など技術的な問題で発生するエラー ex)対象アプリケーションがフリーズ、インターネットに接続しないビジネス例外(業務エラー)
自動化処理処理で使用するデータが不完全、欠損など業務上の不備で発生するエラー ex)入力ミスやファイルが添付されていない、10万円以上は上長承認が必要といった業務上のルールに沿わないデータを含むなど例外をスロー
アクティビティが自動でスローする場合
[Try] 内に [スロー (Throw)] の配置は不要例外を定義してスローする場合
[Try] 内に [スロー (Throw)] を配置※[スロー (Throw)] で例外を作成する場合
new <スローしたい例外の型名>(“エラーメッセージ”)と[例外]プロパティに記載することで、例外を定義し、独自のエラーメッセージを表示させることができます