【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ステートメントは使い方も簡単なので、ぜひ使ってみてくださいね!

Excel VBAを最短で習得したい方へ

元々ITリテラシーの高い方やプログラムの学び方がわかっている方であれば、この記事通りに進めていけば、Excel VBAを独学で習得することができるでしょう。

ただし、実際の学習期間中はつまづいている時間がほとんどです。

「なかなかやり遂げられ無い、挫折してしまった」
「時間が足りない」
「情報が少なくどう調べればいいかわからない」
「エラーを解決することができない」

このような悩みを抱えている方も少なく無いと思います。

  • もう挫折したくない
  • 本業と両立しながら、好きな時間で自分のペースで勉強を続けていきたい
  • 自分だけのカリキュラムで効率的に勉強したい
そんな方はお気軽に侍エンジニア塾までご相談ください。

お一人お一人に専属のインストラクターがつくので、より深くExcel VBAについて学習することできます。

まずは『無料体験レッスン』で、弊社のコンサルタントと一緒にあなた専用の学習方やカリキュラムを考えてみませんか?

Excel VBAならではの学習方法や、現役エンジニアから貴重なアドバイスを受けることができます。

詳しくは下の画像をクリックして弊社サービス内容をご確認ください。

cta2_vba2

LINEで送る
Pocket

書いた人

Sanshiro Wakizaka

Sanshiro Wakizaka

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

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

おすすめコンテンツ

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

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