【ExcelVBA入門】DeleteFolderメソッドを使ったフォルダ削除方法とは

こんにちは、フリーランスエンジニア兼ライターのワキザカ サンシロウです。

皆さんは、VBAでフォルダを削除する方法を知っていますか?

VBAはExcel操作だけでなくフォルダ操作もできるので、ちょっとしたフォルダ整理ツールを作るときにとても便利なんですよね。

そこで今回は、

・VBAでフォルダを削除する方法

といった基礎的なことから、

・フォルダ以下のファイル・サブフォルダを含めて削除する方法

・エラーが出てしまった場合の対処方法

・合わせて覚えると便利なファイルを指定して削除する方法

といった応用的な方法まで、徹底的に解説します!

DeleteFolderメソッドの使い方

はじめに、フォルダを削除する方法について解説します。

フォルダを削除したいときは、FileSystemObjectオブジェクトDeleteFolderメソッドを使います。

フォルダパスで指定したフォルダは、フォルダ内にあるファイルサブフォルダ含めて削除することができます。

このように簡単にフォルダを削除することができます。

サンプルコード

次に、サンプルコードをもとに、具体的な使い方を解説します。

サンプルコード:

FileSystemObjectと聞くと馴染みがない方もいるかもしれませんが、ファイル・フォルダ操作ができるオブジェクト操作方法です。

CreateObject("Scripting.FileSystemObject")」でFileSystemObjectを使うことができるので、決まり文句として覚えてしまえばOKです。

フォルダ削除でエラーが出たときの対処方法

ただ、ファイルを開いている場合フォルダが既に存在していなかった場合DeleteFolderメソッドを使うとエラーになってしまいます。

エラーが起こると処理が途中で止まってしまうだけでなくVBEのコードが表示されてしまうので、ツールを使う人に不信感を与えてしまうときがあります。

そのため、エラー処理を組み込んでおくのがおすすめです!

エラー処理を入れたサンプルコード:

フォルダがない場合のエラー:

ファイルを開いている場合のエラー:

エラーの場合はエラーメッセージをMsgBoxで表示するように処理を書いています。

また、メインの処理ではフォルダがあった場合のみ、以下のメッセージが表示されるようにしています。

メッセージ:

VBAでツールを作るときは、このようなちょっとした配慮をするだけで、使い勝手がぐっと上がるのでおすすめです!

サンプルで紹介したフォルダ存在チェック方法エラー処理の書き方については以下で詳しく解説しているので、気になる方は見てみてくださいね!

VBAでファイル名を取得するには?3+1のパターンで速攻理解!
更新日 : 2019年4月25日
【VBA入門】エラーを処理する方法(On Error、Resume、GoTo)
更新日 : 2019年4月21日

補足:合わせて覚えると便利なファイル削除方法とは

今回はフォルダ削除に特化して解説していますが、ファイルを指定して削除したいケースもありますよね。

以下で詳しく解説しているので、合わせて覚えるのがおすすめです!

まとめ

今回は、VBAでフォルダを削除するためのDeleteFolderメソッドの使い方について解説しました。

VBAでフォルダ削除ができるようになると、効率的に速くフォルダ整理ができるようになります。

使い方も簡単なので、ぜひ使ってみてくださいね!

LINEで送る
Pocket

最短でエンジニアを目指すなら侍エンジニア塾

cta_under_bnr

侍エンジニア塾は業界で初めてマンツーマンレッスンを始めたプログラミングスクールです。これまでの指導実績は16,000名を超え、未経験から数多くのエンジニアを輩出しています。

あなたの目的に合わせてカリキュラムを作成し、現役エンジニア講師が専属であなたの学習をサポートするため効率よく学習を進めることができますよ。

無理な勧誘などは一切ありません。まずは無料体験レッスンを受講ください。

無料体験レッスンの詳細はこちら

書いた人

Sanshiro Wakizaka

Sanshiro Wakizaka

フリーランスエンジニア兼ライターのワキザカ サンシロウです。
ExcelVBAの自動化ツール開発、WEB開発をメインにエンジニア業務をこなしつつ、サムライエンジニアにてライター業務をしております。

プログラミングをこれからやってみたい方に向けて、ためになる記事を全力で書いていきますので宜しくお願い致します!

おすすめコンテンツ

あなたにぴったりなプログラミング学習プランを無料で診断!

プログラミング学習の効率を劇的に上げる学習メソッドを解説