【ExcelVBA入門】Killステートメントでファイルを削除する方法とは

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

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

ちょっとしたフォルダ整理をしたいとき、フォルダ管理ツールを作りたいときなど、ファイルの削除方法を知っているととても便利です。

そこで今回は、

・ファイルパスを指定して削除する方法

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

・フォルダ内のファイルを一括で削除する方法

・ファイル削除以外のファイル操作方法

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

VBAでファイルを削除する方法とは

最初に、VBAでファイルを削除する方法について解説します。

以下のように書くことで、ファイルを削除することができます。

とてもシンプルですよね。

ファイルパスのファイル名はワイルドカード(*)が使えるため、複数のファイルを一括で削除することもできます。

Noファイル名意味
1*.*全てのファイル
2Sample*ファイル名がSampleで始まる全てのファイル
3*Sampleファイル名がSampleで終わる全てのファイル
4*.xlsx拡張子が 「 .xlsx 」 のすべてのファイル

サンプルコード

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

ファイルパスを指定して削除

まずは、1ファイルのみ削除するケースですね。

実行前:

サンプルコード:

実行後:

VBAのファイルと同じパスにある、「削除ファイル.xlsx」を削除しています。

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

フォルダを指定してすべて削除

次に、一括でファイルを削除する方法について解説します。

実行前:

サンプルコード:

実行後:

拡張子が「.txt」のファイルをすべて削除するサンプルです。

ワイルドカード(*)さえ覚えておけば簡単に一括削除することができます。

削除するファイルがなかった場合の対処方法

Killステートメントはとても便利なのですが、既にファイルが削除されていた場合、エラーメッセージが出てしまいます。

そのため、事前にファイルがあるか確認する処理を入れるのがおすすめです。

Dir関数を使えば簡単にファイルの存在チェックができるので、使い方がわからない方は以下を見るのがおすすめです!

VBAでファイル名を取得するには?3+1のパターンで速攻理解!
更新日 : 2019年4月25日

補足:ファイル操作について詳しく知りたい方へ

今回はファイル削除に特化して解説していますが、ファイル操作は一通り覚えておくと応用が利くのでおすすめです!

ファイルオープンファイル出力名前を付けて保存上書き保存などそれぞれ詳しく以下でまとめているので、ぜひ見てみてくださいね!

【VBA入門】OpenメソッドでテキストファイルやCSVの読み込み
更新日 : 2019年5月26日
【ExcelVBA入門】ファイルを出力しよう!Open・Print・Closeの使い方
更新日 : 2019年4月30日
【ExcelVBA入門】SaveAsメソッドを使ったファイル保存方法を徹底解説!
更新日 : 2019年4月2日
【ExcelVBA入門】Saveメソッドでファイルを上書き保存する方法とは
更新日 : 2018年8月17日

まとめ

今回は、VBAでファイルを削除する方法について解説しました。

ファイル操作ができると、ちょっとした便利ツールが作れるのでおすすめです!

今回解説したKillステートメントは使い方も簡単なので、ぜひ使ってみてくださいね!

LINEで送る
Pocket

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

cta_under_bnr

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

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

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

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

書いた人

Sanshiro Wakizaka

Sanshiro Wakizaka

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

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

おすすめコンテンツ

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

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