UiPathでExcelを操作する(活用編: 名前を付けて保存する)


UiPathでExcelを自由に操作する(活用編: 名前を付けて保存する)

概要

前回の基本編でWorkbookの取得方法をご紹介しました。
https://qiita.com/takusonix/items/ebb71c7b2674a116c33a

この記事では取得したWorkbookを活用して、Excelの名前を付けて保存するカスタムアクティビティの作り方をご紹介します。
※この記事は、名前を付けて保存する実装のみを記載しおり、不完全版です。
業務で使用する場合、下記の完成版の実装をご利用ください。
https://qiita.com/takusonix/items/d8070b61c06900d75c92

お約束事項(免責事項)

  • この記事は2020年6月時点の情報を基に作成しております。
  • 記事の内容は私個人の見解であり、所属する組織の公式見解ではありません。

スキル

この記事には、C#によるカスタムアクティビティの開発が含まれます。
カスタムアクティビティの開発方法は、UiPath公式のドキュメントを参照ください。
(本記事では最低限のみ記載します。)
https://docs.uipath.com/activities/lang-ja/docs/creating-a-custom-activity

必要なソフトウェア

  • Visual Studio
  • Nuget または Nuget Package Explorer
  • Microsoft Office

実装内容の確認

実装の前に、名前を付けて実装する内容を確認します。

1. Excelを開く

新しいExcelを開いてください。

2.マクロの記録を実行する

開発タブからマクロの記録を選択します。
マクロ名はデフォルトのままで構いません。

3.名前を付けて保存する

ファイルを選択し、名前を付けて保存から参照を教えて、適当な場所に保存します。


保存時に表示される確認メッセージは、「はい」を選択して回避する

4. マクロを停止する

開発タブから、停止を押してマクロの記録を停止します。

5.記録したマクロを確認する

同じ開発タブから、マクロボタンを押し、記録したマクロを編集ボタンを押して内容を確認します。

6.実装内容の確認

以下が、実装内容になります。
ここのActiveWorkbookが前回の記事の基礎編でご消化したWorkbookに置き換えるだけです。

    ActiveWorkbook.SaveAs Filename:="C:\Users\stell\Documents\Sample\Book1.xlsx" _
        , FileFormat:=xlOpenXMLWorkbook, CreateBackup:=False

手順

1.プロジェクトを開く

基礎編で使用したVisual Studioでクラスプロジェクトを開きます。

2.クラスファイルを追加する

SaveAs.csのクラスファイルを追加します。

3.参照の追加

基礎編で追加済みの場合は不要です。

  1. UiPath公式のガイド通り、「System.Activities」と「System.ComponentModel.Composition」を追加します。
  2. 次に参照の追加で「COM」を選択し、「Microsoft.Excel XX Object Library」を選択します。
    ※Officeがインストールされてない場合、表示されません。

4.実装

コードは下記のとおりです。
ビルドの仕方、Nuget Packageの作り方は割愛します。(笑)

using Microsoft.Office.Interop.Excel;
using System;
using System.Activities;
using System.ComponentModel;

namespace UiPathCustomLibrary
{
    public class SaveAs : CodeActivity
    {
        [Category("Input")]
        [RequiredArgument]
        public InArgument<Object> WorkbookApplication { get; set; }
        [Category("Input")]
        public InArgument<Object> FileName { get; set; }
        protected override void Execute(CodeActivityContext context)
        {
            object workbookapp = WorkbookApplication.Get(context);
            Workbook workbook = workbookapp.GetType().GetProperty("CurrentWorkbook").GetValue(workbookapp) as Workbook;

            workbook.SaveAs(Filename: FileName.Get(context), FileFormat: XlFileFormat.xlOpenXMLWorkbook, CreateBackup: false);
        }
    }
}

SaveAsの実装途中で、引数についてヒントも確認できます。

5.実行確認

Nuget Package Explorerで作成したライブラリをUiPath Studioでインストールした後、早速使ってみます。
「c:\tmp\Sample2.xlsx」として名前を付けて保存します。
※ 保存先は絶対パスで指定してください。

おまけ

(失敗談)ファイル名だけ指定して実行する

カスタムライブラリで実行すると、作業ディレクトリ(Environment.CurrentDirectory)がロボットプロジェクトの場所ではなく、
カスタムライブラリーのプロジェクトフォルダに移ります。
そのため、ファイル名だけ指定して実行すると、想定外の場所に出力されます。