皆もすなるQiitaといふものを、儂もしてみむとてするなり。
と言う訳で、こん**は!はなっち!です。
【初めに】
従来のお客様先での開発は、Microsoft製品をターゲットにした入出力がメインでした。
先日、とある案件で、「Google Workspaceでメール、ドライブ、スプレッドシートの経験」が求められ、ありゃ経験ないやってんで、失注しました。あぁ悔しい。
この状態を受けて、ただ手を拱いていては成長しないので、自分のGoogle環境で試行錯誤してみました。
今回は、GSuiteアクティビィティを使って、Googleサービスへ接続する方法に関してまとめてみます。
1)「GSuite」アクティビティをインストールする。
UiPath Studioの「パッケージを管理」から、「オフィシャル」をアクティブにして、検索テキストボックスにて、GSUITE
と入力します。
出てきた「Google Workspace」を選択し、インストールします。
アクティビティパネルの「連携」⇒「Google」配下に、(ちょっと未整理のようですが)使用できるアクティビティが並びます。
ちょっと散漫としちゃっていますので、ちょっと古いものですが、Ver1.16.2で行ってみます!
2)「GSuite」アクティビティで何ができるの?
先に展開したアクティビティパネルの一覧から見える機能が使えます。
・Apps Script
・Gmail
・シート(SpreadSheetですね)
・ドキュメント
・ドライブ
・予定表/カレンダー
本家Googleでは使えるけど、UiPathからは実現できない!って機能は、今後のお楽しみって事で(Ver2.0.1では、[ドライブ]->[トリガー]に、トリガー系のアクティビティが増えています)。
3)早速使ってみる
Google の機能を使用するアクティビティを一つ選択して、例えばドライブの中にある「ファイルやフォルダーを探す」を、ドラッグ&ドロップしてみましょう。
エラーですorz。
エラー画面にあるように、Google の機能を使用する場合は、Googleの認証も扱うアクティビティ、「Google ドライブを使用」または、「GSuite アプリケーション スコープ」が必要です。
- 「Google ドライブを使用」 ... ドライブ関係の機能を使う際に必要。
- 「GSuite アプリケーション スコープ」 ... ドライブ関係の機能を使うだけにとどまらず、他の機能を使う際に必要。
Google の機能を使用するには、Google アカウントを、アクティビティに教えてあげるためのアクティビティが必要ですね。
4)「Google ドライブを使用」
「Google ドライブを使用」を配置して、その中のシーケンスの中に、「ファイルやフォルダーを探す」を配してみましょう。
「ファイルやフォルダーを探す」自身のエラーはなくなりましたね?
しかし、次のエラーが発生してしまいました!
Google アカウントを設定しなければなりませんね。
5)アカウントの設定
「Google ドライブを使用」アクティビティのプロパティを見ると、
アカウントとか、Integration Serviceとか、設定する項目がありますね。
「Google ドライブを使用」アクティビティ本体にもアカウント設定の場所があります。
まずは、「Google ドライブを使用」アクティビティ本体から設定してみましょう。
下へスクロールすると、許可する対象リストが出てきますので(この場合は、[Google ドライブのすべてのファイルの表示、編集、作成、削除です。])、チェックONして、「続行」をクリックします。
こんな画面が出てきたら設定完了。この窓は閉じていただいて大丈夫です。
こんな画面になって、エラーもなくなりましたね。
この方法での注意点は以下の通りです。
・1アクティビティで実現できる!
・ただ、「繰り返し(各行)」アクティビティで一行一行実施しなければならない。
・それを逆手にとって、対象行かどうかを「条件分岐」アクティビティで判断し、そのロジックの中で加工した行を転記出来る。
・流石に文字属性⇔数値属性は難しいけど、EXCEL⇒CSV、CSV⇒EXCELならそう問題は起きにくいでしょう。
【まとめ】
・列の並びの変更にはいろんな方法があり、いろんな癖があり、開発者の好みによる事でしょう。
・列の並びの変更後のDataTable域は、変更前のDataTable域の発生源と同じ方式で作成した方が楽。例えばCSVだったら、変更後の列の並びだけのCSVを読み込み、0行のDataTable域を準備する。
##おわりに
いかがでした?
今回も読んでいただきありがとうございました!
是非UiPathでのロボ開発の一助になればと思っています。
ありがとうございました!