【Power Automate Desktop】特定のフォルダとそのサブフォルダ(任意の複数階層)をコピーする
- 1.やりたいこと
- 2.実践① フロー作成 ~ 新しいフォルダの作成
- 3.実践② Switch条件の設定 ~ 各階層サブフォルダの作成ループ処理
- 4.実践③ コピー階層の選択2と1の場合(それぞれサブフローを設定)
- 5.フローの実行/確認
1.やりたいこと
みなさん、自身のPCのフォルダはどのように管理しているでしょうか。
私は下図のように会計年度毎に各項目に分けてフォルダ管理することが多いのですが、これまでは当年度が終わる前に翌年度用のフォルダをまた一から作り直していました。よくよく考えたらこれはすごく無駄な作業だと思います。かといって、当年度のフォルダをまるまるコピーするとその中のすべてのドキュメントもコピーされてしまい、時間をかけてコピーした後にファイルを削除するというかなりの手間が掛かってしまいます。はじめから数年分の空フォルダを作っておいても1年の間でフォルダ体系は変わってしまいます。
そこで、今回PADを使って同じ体系のままフォルダのみをコピーする仕組みを考えてみました。
長くなりますので、全体の流れとポイントを要約したものを下図にまとめました。
2.実践① フロー作成 ~ 新しいフォルダの作成
トップ画面から、新しいフローをクリックします。
任意の名前を付けて作成ボタンをクリックします。
画面左のアクション一覧からフォルダ→特別なフォルダーを取得 をダブルクリック(又は真ん中のフロー詳細へドラッグ&ドロップ)します。このアクションは以降のファイル選択等の際に「初期フォルダ」を設定するために変数化しておくものです。
ここでは、特別なフォルダ―の名前: デスクトップ を選択します。特別なフォルダーのパス:は自身のデスクトップのパスが自動設定されます。生成された変数はデフォルトの SpecialFolderPath のままとし、保存します。
【コピー対象フォルダを選択をするためのダイアログ設定】
アクション一覧 → メッセージボックス → ファイルの選択ダイアログを表示 をダブルクリックします。
下図の通り入力し保存します。
ダイアログの説明: コピー対象のフォルダを選択(任意のテキスト)
初期フォルダ:%SpecialFolderPath% (右端の{X}をクリックし、変数名を選択)
フォルダ―選択ダイアログを常に手前に表示する:オン
生成された変数:デフォルトの SelectedFolder を CopyFolder に変更します。変数名は後続の処理を考慮して極力わかりやすい名前にしておいた方がよいです。変数ButtonPressedは今回特に使用しませんのでデフォルトのままとします。
【コピー対象フォルダのサブフォルダ(1階層目)のフォルダを取得】
アクション一覧 → フォルダ― → フォルダ―内のサブフォルダーを取得 をダブルクリックします。
下図の通り入力し保存します。
フォルダ―:%CopyFolder% (右端の{X}をクリックし、変数名を選択)
フォルダ―フィルター:*(デフォルトのまま)
サブフォルダーを含める:オフ
※ここをオンにしてしまうと、1階層目に2階層目以降のフォルダが含まれてしまうため、必ずオフにする必要があります。
生成された変数:SubFolders に変更します。
【コピー階層選択用のリストを設定】
アクション一覧 → 変数 → {x}変数の設定 をダブルクリックします。
下図の通り入力し保存します。
設定: SelectList (任意の変数名)
宛先: %[3,2,1]% と入力。
変数をリストにする場合は、値を [] で括り , で区切る必要があります。リストの順は%[1,2,3]%でもよいのですが、使用頻度を考慮して今回は降順にしています。
【コピー階層選択用のリストダイアログを設定】
アクション一覧 → メッセージボックス → リストから選択ダイアログを表示 をダブルクリックします。
下図の通り入力し保存します。
ダイアログのタイトル:コピー対象フォルダの階層数選択(任意)
ダイアログメッセージ:コピー対象フォルダに含まれるサブフォルダのうち、何階層目までをコピーするか選択してください。(1~3) (任意)
選択元のリスト: %SelectList% (右端の{X}をクリックし、変数名を選択)
選択ダイアログを常に手前に表示する:オン
リストに制限:オン
空の選択を許可:オフ
複数の選択を許可:オフ
生成された変数: SelectedItem(デフォルトのまま)、SelectedIndex と ButtonPressed3は今回使用しないためこちらもデフォルトのままで結構です。
【新規コピー先のフォルダ名の入力ダイアログ設定】
アクション一覧 → メッセージボックス → 入力ダイアログを表示 をダブルクリックします。
下図の通り入力し保存します。
入力ダイアログのタイトル:コピー先のフォルダ名を入力(任意)
入力ダイアログメッセージ:ブランク(必要に応じて任意入力)
規定値:ブランク
入力の種類: 1行(デフォルトのまま)
入力ダイアログを常に手前に表示する:オン
生成された変数 NewFolderName に変更します。ButtonPressed2は今回使用しない為デフォルトのままで結構です。
【新規コピー先のフォルダの作成】
アクション一覧 → フォルダー → フォルダ―の作成 をダブルクリックします。
下図の通り入力し保存します。
新しいフォルダーを次の場所に作成:%CopyFolder.Parent% と入力。
※プロパティ「.Parent」を使用します。これにより、CopyFolder の親フォルダ、つまり、コピー元フォルダと同じ場所に新しいフォルダーが作成されることになります。
新しいフォルダー名: %NewFolderName %(右端の{X}をクリックし、変数名を選択)
ここまでで作成したフローは下図の通りとなります。
3.実践② Switch条件の設定 ~ 各階層サブフォルダの作成ループ処理
ここから各階層ごとにフォルダのコピーを行う設定をしていきます。
【コピー階層の選択結果に応じた条件の設定】
恐らく If条件でも設定できると思いますが、折角なのでSwitch条件を使ってみました。ExcelのSwitch関数と同じ考え方だと思います。
アクション一覧 → 条件 → Switch をダブルクリックします。
下図の通り入力し保存します。
チェックする値:%SelectedItem%(右端の{X}をクリックし選択)
【コピー階層選択が3(階層)の場合を設定】
アクション一覧 → 条件 → Case をダブルクリックします。
下図の通り入力し保存します。
演算子: と等しい(=) を選択
比較する値: 3 を入力
【フォルダ作成(1階層目)のループ処理】
アクション一覧 → ループ → For each をダブルクリックします。
変数SubFoldersを変数CurrentItemに入れ、CurrentItemの数分フォルダのコピーを繰り返します。
下図の通り入力し保存します。
反復処理を行う値: %SubFolders% (右端の{X}をクリックし選択)
生成された変数: CurrentItem (デフォルトのまま)
【1階層目処理を示すコメントを設定】
任意ですが、後続の処理でわかりやすいようにコメントを入れておきます。
アクション一覧 → フリーコントロール → コメント をダブルクリックします。
コメント:任意のコメントを入力し保存します。
【新規フォルダにサブフォルダ(1階層目)をコピーするためのフォルダ名取得】
アクション一覧 → テキスト → テキストを置換する をダブルクリックします。
下図の通り入力し保存します。
解析するテキスト:%CurrentItem% (右端の{X}をクリックし選択)
検索するテキスト:%CopyFolder% (右端の{X}をクリックし選択)
検索と置換に正規表現を使う:オフ
大文字と小文字を区別しない:オフ
置き換え先のテキスト: %''% を入力
※ブランクに置き換えたいのですが、ここをブランクにするとエラーとなるので、このように%’’%(シングルクオーテーション2つ)を入力します。
生成された変数: NewSubFolderName に変更します。
以下、実際に最初に変数に入る値を例として補足します。
① 解析するテキスト:CurrentItem → C:\Desktop\2020年度\00_日時関係
② 検索するテキスト:CopyFolder → C:\Desktop\2020年度
③ ①の中の②をブランクにする。 → \00_日時関係
となります。ただ、このままだと頭に余計な \ が残ってしまうので次のアクションで取り除きます。
再び、アクション一覧 → テキスト → テキストを置換する をダブルクリックします。
下図の通り入力し保存します。
解析するテキスト:%NewSubFolderName% (右端の{X}をクリックし選択)
検索するテキスト: \
検索と置換に正規表現を使う:オフ
大文字と小文字を区別しない:オフ
置き換え先のテキスト: %''% を入力
生成された変数: NewSubFolderName として変数を上書きします。
【 新規フォルダにサブフォルダ(1階層目)を作成】
アクション一覧 → フォルダー → フォルダ―の作成 をダブルクリックします。
下図の通り入力し保存します。
新しいフォルダを次の場所に作成:%Newfolder% (右端の{X}をクリックし選択)
新しいフォルダ名: %NewSubFolderName% (右端の{X}をクリックし選択)
生成された変数: NewSubfolder に変更します。
【2階層目処理を示すコメントを設定】
任意ですが、後続の処理でわかりやすいようにコメントを入れておきます。
アクション一覧 → フリーコントロール → コメント をダブルクリックします。
コメント:任意のコメントを入力し保存します。
【1階層目のサブフォルダ(2階層目)を取得】
アクション一覧 → フォルダ― → フォルダ―内のサブフォルダーを取得 をダブルクリックします。
下図の通り入力し保存します。
フォルダ―: %CurrentItem% (右端の{X}をクリックし選択)
フォルダ―フィルター:*(デフォルトのまま)
サブフォルダーを含める:オフ
生成された変数: SubFolders2 に変更します。
前述の例だとこのCurrentItemは C:\Desktop\2020年度\00_日時関係
となります。つまり、00_日時関係 のサブフォルダ(2階層目)が取得されることになります。
【フォルダ作成(2階層目)のループ処理】
アクション一覧 → ループ → For each をダブルクリックします。
変数SubFolders2を変数CurrentItem2に入れ、CurrentItem2の数分フォルダのコピーを繰り返します。
下図の通り入力し保存します。
反復処理を行う値: %SubFolders2% (右端の{X}をクリックし選択)
生成された変数: CurrentItem2 (デフォルトのまま)
【新規フォルダのサブフォルダ(1階層目)にサブフォルダ(2階層目)をコピーするためのフォルダ名取得】
アクション一覧 → テキスト → テキストを置換する をダブルクリックします。
下図の通り入力し保存します。
解析するテキスト:%CurrentItem2% (右端の{X}をクリックし選択)
検索するテキスト:%CurrentItem% (右端の{X}をクリックし選択)
検索と置換に正規表現を使う:オフ
大文字と小文字を区別しない:オフ
置き換え先のテキスト: %''% を入力
生成された変数: NewSubFolderName2 に変更します。
以下、前述と同様に実際に最初に変数に入る値を例として補足します。
①解析するテキスト:CurrentItem2→C:\Desktop\2020年度\00_日時関係\00_未処理事項
②検索するテキスト:CurrentItem → C:\Desktop\2020年度\00_日時関係
③ ①の中の②をブランクにする。 → \00_未処理事項
となります。ただ、このままだと頭に余計な \ が残ってしまうので次のアクションで取り除きます。
再び、アクション一覧 → テキスト → テキストを置換する をダブルクリックします。
下図の通り入力し保存します。
解析するテキスト:%NewSubFolderName2% (右端の{X}をクリックし選択)
検索するテキスト: \
検索と置換に正規表現を使う:オフ
大文字と小文字を区別しない:オフ
置き換え先のテキスト: %''% を入力
生成された変数: NewSubFolderName2 として変数を上書きします。
1階層目の時はこの置換まででうまくいったのですが、2階層目以降はこの置換までで実行するとなぜか余計な空白が含まれた状態となってしまい実行時エラーとなります。そのため、次のトリミング処理を追加します。
アクション一覧 → テキスト → テキストのトリミング をダブルクリックします。
下図の通り入力し保存します。
トリミングするテキスト: %NewSubFolderName2% (右端の{X}をクリックし選択)
トリミング対象: 先頭と末尾の空白文字 を選択します。
【 新規フォルダにサブフォルダ(2階層目)を作成】
アクション一覧 → フォルダー → フォルダ―の作成 をダブルクリックします。
下図の通り入力し保存します。
新しいフォルダを次の場所に作成:%NewSubfolder% (右端の{X}をクリックし選択)
新しいフォルダ名: %NewSubFolderName2% (右端の{X}をクリックし選択)
生成された変数: NewSubfolder2 に変更します。
ここからは3階層目の設定になりますが、2階層目の設定と同じ内容となりますので画面のみの貼り付けとし、説明は省略します。
ここまでで3階層目のフォルダコピー処理が完了です。ここで設定したフローは以下の通りです。
4.実践③ コピー階層の選択2と1の場合(それぞれサブフローを設定)
次に最初のコピー階層の選択で2、1を選択した場合の分岐処理を設定していきます。単純にそれぞれのケース毎に先ほどのアクションを減らしたものを追加してもよいのですがフロー全体がかなり長くなってきたこともありますので、それぞれのケース毎にサブフローを設定することにします。
【コピー階層選択が2(階層)の場合を設定】
アクション一覧 → 条件 → Case をダブルクリックします。
下図の通り入力し保存します。
演算子: と等しい(=) を選択。
比較する値: 2 を入力。
次に画面上の サブフロー をクリックします。
+ 新しいサブフローをクリックします。
任意のサブフロー名を入力し保存します。
今回は、Subflow_1_Case_2 とします。
Mainフロータブの隣に新しいサブフロータブが作成されました。
次に一旦Mainフローに戻り、下図の通りCase3の次の For eachアクションからCase2の前のEndまでを選択し、Ctrl+C(又は右クリックでコピーを選択)でコピーします。
サブフロータブをクリックし、Ctrl+V(又は右クリック→貼り付け)で貼り付けます。
コメント(3階層目)から次のEndまでは不要となりますので下図の通り選択し削除します。
Subflow_1_Case_2 はこれで完了です。下図の通りのフローとなります。
再び、Mainフローに戻ります。Case2の下に作成したサブフローの実行を設定します。
アクション一覧 → フリーコントロール → サブフローの実行 をダブルクリックします。
Subflow_1_Case_2 を選択し保存します。
Case2の下にサブフローの実行が設定されました。
【コピー階層選択が1(階層)の場合を設定】
アクション一覧 → 条件 → Case をダブルクリックします。
下図の通り入力し保存します。
演算子: と等しい(=) を選択。
比較する値: 1 を入力。
この後のサブフローの設定は先ほどほぼ同じで、最後に削除する部分が増えるだけですので説明は省略します。
Subflow_1_Case_1 のフローは下図の通りとなります。
Mainフローの末尾は次の通りとなります。
これですべてのフローの設定は完了となります。設定したMainフロー全体は下図の通りです。
5.フローの実行/確認
【フローの実行】
詳細設定画面から実行するとデバッグモードで実行され時間が掛かる為、作成したフローを一旦保存後に閉じて、トップ画面から実行します。
コピー対象フォルダ選択ダイアログが表示されるので対象フォルダを選択し、OKをクリックします。
次にコピー対象フォルダの階層数選択ダイアログが表示されます。今回は3を選択し、OKをクリックします。
続いて、コピー先のフォルダ名入力ダイアログが表示されるので、任意の名称を入力しOKをクリックします。今回は 2021年度 とします。
その後、コピー処理が実行されます。わずか2秒で完了しました。
【結果の確認】
コピー元のフォルダ 「2020年度」と同じ場所に「2021年度」が作成されました。
ドリルダウンしてみると、1階層目のフォルダが作成されています。
更に1階層目の「00_日時処理」をドリルダウンします。
2階層目のフォルダも作成されています。
更に2階層目の「00_未処理事項」をドリルダウンします。
3階層目のフォルダまできちんと作成されたことが確認できました。
以上となります。