RPAツールUiPathを使って出退勤時刻を記録する
概要
UiPathを使う機会があったため、試しに毎日の出退勤時刻記録を自動化してみます。※1
今回はあらかじめ勤怠の記録用に作成しておいたExcelファイルに出勤時刻と退勤時刻を記録できるようにすることが目標です。
※1 UiPathを実行した日時の出退勤時刻を記録します。
実行環境
- OS:Windows 7
目次
- 事前準備
- UiPath(UiPath Studio)のインストールの実施
- Excelファイルの作成
- 出勤時刻記録ロボットの作成
- プロジェクトの作成
- 出勤時刻の取得
- 出勤時刻の記録
- 実行
- クリック動作用バッチ作成
- 退勤時刻記録ロボットの作成
1. 事前準備
ここでは下記の二つを行います。
- UiPath(UiPath Studio)のインストールの実施
- Excelファイルの作成
1. UiPath(UiPath Studio)のインストールの実施
公式ホームページより指定された情報を入力しインストールを行います。
指定要件を満たしていると無料で利用できるCommunity版もあります。
2. Excelファイルの作成
自分の出勤時刻等を記録するためのExcelファイルを作成しておきます。
今回は下記のようなExcelファイルを作成しました。
2. 出勤時刻記録ロボットの作成
それではインストールしたのUiPath Studioを起動して勤怠記録用のロボットを作成します。
1. プロジェクトの作成
起動画面から「Simple Process」をクリックします。
プロジェクトディレクトリ名(Name)と配置場所(Location)、プロジェクト概要(description)を記載し、「Create」を押下します。
画面中央のパネル(メインパネル)にデフォルトで作成されているものがありますので、「Start」を除いて削除します(下図赤枠部分)。
削除は削除したいアクティビティ(Data Input等)を選択してdeleteキーで削除できます。
まずは、画面左側のパネル(アクティビティパネル)から今回に必要な作業フローとして「Sequence」をメインパネルにドラッグ&ドロップします。
アクティビティパネルに検索が用意されているのでそれで探すと便利です。
配置した「Sequence」の名称をクリックすると名称の変更ができるので見返した際にわかりやすいよう適宜名称を変更します。
ドロップした「Sequence」を「Start」のアクティビティとつないでおきます。
2. 出勤時刻の取得
メインパネルに配置されている「Sequence」(出勤時刻の取得)をダブルクリックします。
すると「Sequence」アクティビティ内の編集に移ります。
この中では出勤時刻を取得するためにアクティビティパネルから「Assign」を二つ配置します。
ここでは、配置した「Assign」を「月日の取得」と「時刻の取得」に名称変更しておきます。
次に今回使用する変数を定義しておきます。
画面下部のタブにある「Variables」をクリックします。ここではこのプロジェクトで利用できる変数を定義しておくものです。
今回は、「days」と「time」の二つの変数を作成します。
作成のやり方は次の通りです。
- 「Create Variable」をクリックして変数名を入力します
- 作成した変数行の「Variable type」を「String」に変更します ※2
- 「Scope」を「Main」に変更します ※3
※2 変数の型を変更しています
※3 変数の利用範囲を変更しています
変数を作成したら配置済みの「Assign」の「To」に作成した変数名を設定します。
そして「=」をはさんだ右側の入力欄(「Value」)には下記の記述を行い、ロボット実行時の月日と時刻を変数に格納するようにします。
- 月日の取得:「Today.ToString("MM/dd")」
- 時刻の取得:「Now.ToString("HH:mm")」
ここまでで出勤時刻の取得は完了です。画面左上の「Main > Main > 出勤時刻の取得」の「Main」をクリックし元の画面に戻ります。
3. 出勤時刻の記録
次に「出勤時刻の記録」の「Sequence」をダブルクリックし、出勤時刻の記録部分を作成します。
この「Sequence」の中では下記のことを行います。
- 出勤時刻の書き込み先Excelファイルの指定
- excelファイル内の書き込み日付箇所の特定
- 出勤時刻の記載
1. 出勤時刻の書き込み先Excelファイルの指定
Excelファイルの指定を行います。
アクティビティパネルから「Excel application scope」をメインパネルに配置します。
「Excel application scope」内の「Workbook path. Text must be quoted」の部分に記載を行うExcelのファイルパスを記載します。
2. Excelファイル内の書き込み日付箇所の特定
出勤時刻は、このロボットを実行した日付けに出勤時刻のセルに記入する必要があります。
そのため(実際他にもっと便利な方法はあるかもしれませんが)今回は下記の方法で記載セルを特定し記載します。
- Excelの「A」の列のセルを取得する
- 取得した「A」のセルの内、「days」変数に格納されている今日の日付と一致する行番号を取得する
- 「B」列+今日の日付と一致した行番号の欄を指定して出勤時刻を記載する
そのため、まずは、「A」列のセルを取得します。アクティビティパネルから「Read Column」をメインパネルに配置します。
そして、配置した「Read Column」にクリックすると右側のパネル(プロパティパネル)に「Read Column」の情報が表示されます。
その中の「Result」では読み込んだExcel情報を格納する変数を設定できます。
「Result」の入力欄をクリックし、「Ctrl + k」を押します。すると、「Variable」での変数作成と同じく利用する変数を設定することができますので、「Set Name」の表記に続いて、変数名(今回は「readColumn」)を設定します。
これで変数「readColumn」の中にA列のセル情報が入るようになります。
次にA列の中から本日日付を取得します。
アクティビティパネルから「For each」アクティビティをメインパネルに配置し、「in」の後の入力欄にA列のセル情報を格納してある「readColumn」を指定します。
こうすることで、「For each」アクティビティはreadColumnに格納されている情報の数だけループ処理を行います。
その中で本日日付にあたる場合のみ、出勤時刻の書き込み処理を行いたいため、条件処理の分岐判定を行います。
アクティビティパネルから「if」を「For each」内の「body」に配置します。
そして条件を判定する「Condition」には「item.ToString = days」を記載します。
この記載によって本日日付の場合だったら、「If」アクティビティ内の「Then」の処理が実行されます。
3. 出勤時刻の記載
出勤時刻の記載を行うセル番号を指定するためにセル番号のカウンタを作成します。
「Variables」から変数として「cellCount」を作成し、「Variable type」を「Int32」、「Scope」を「出勤時刻の記録」で作成します。
アクティビティパネルから「Assign」をメインパネルの「For each」前に配置し、作成した変数「cellCount = 1」を設定します。
次に「If」の中の「else」部分に「Assign」を配置し「cellCount = cellCount + 1」を指定します。
この操作で本日日付と一致するまで、セル番号が一つずつ増えていきます。
では最後にExcelに出勤時刻を書き込みます。
アクティビティパネルから「Write Cell」をメインパネルの「If」の「Then」内部に配置し、
「A value or a formula. Text must be quoted」に出勤時刻として「time」を記載します。
また、記載するセルとして「"B" + cellCount.ToString」を記載します。
4. 実行
出来上がったロボットを実行します。
UiPath Studioの画面上部の「Run」もしくは、「F5」キーで実行できます。
問題なく動作すれば、指定の日時に記載が行われているはずです。
実行後ファイル
3. クリック動作用バッチ作成
毎回UiPathを開いて実行する(もしくは実行コマンドを入力する)のは面倒なので、簡単なバッチファイルを作ります。
UiPath Studioをインストールした際に入ってくる「UiRobot.exe」を指定しつつ引数に作成したロボットのパスを「/file:」以下に記載します。
今回の場合、下記のようなバッチファイルになります。
@echo off
rem %filePath%の部分に作成したロボットのパスを記載します
call "C:\Program Files (x86)\UiPath Studio\UiRobot.exe" /file:"%filePath%Main.xaml"
exit /b 0
あとはバッチファイルの紐付を行えば、ダブルクリックだけで出勤記録をつけることができるようになります。
4. 退勤時刻記録ロボットの作成
基本的に出勤時刻記録ロボットと同じです。出勤時刻記録ロボットのファイル(Main.xaml)をコピーします。
コピーしたファイルの中から「Write Cell」で記載するセルを「"B" + cellCount.ToString」から隣のセル「"C" + cellCount.ToString」に変更するだけで退勤時刻を記録できます。