スライドショースライドショー

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

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

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

そこで今回は、

  • ファイルパスを指定して削除する方法
  • フォルダ内のファイルを一括で削除する方法
  • ファイル削除以外のファイル操作方法

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

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

最初に、VBAでファイルを削除する方法について解説します。以下のように書くことで、ファイルを削除することができます。

Kill ファイルパス

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

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

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

サンプルコード

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

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

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

実行前:

サンプルコード:

Sub Test1()
  Dim filePath As String
  filePath = ThisWorkbook.Path & "\"
  
  Kill filePath & "削除ファイル.xlsx"
End Sub

実行後:

VBAのファイルと同じパスにある、「削除ファイル.xlsx」を削除しています。このように、簡単にファイルを削除することができます。

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

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

実行前:

サンプルコード:

Sub Test2()
  Dim filePath As String
  filePath = ThisWorkbook.Path & "\"
  
  Kill filePath & "*.txt"
End Sub

実行後:

拡張子が「.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

無料でSEからWebエンジニアへ転職しませんか?



侍エンジニア塾では、完全未経験の方から現在SEだけどプログラミングはやっていないという経験者まで、幅広い方々の人生を好転させるプログラミング指導を行ってきました。SEの方とお話していくなかで、

  • システムエンジニアという職業だけどコードが書けない
  • 事務作業が多くスキルがないため将来が不安
  • スクールに通うと完全未経験者と同じスタートになるからレベルが合わない
という、すでに知識があるSEならではのお悩みがあることに気づきました。そんな方におすすめなのが、弊社の「転職コース 」です。

弊社では、マンツーマンでレッスンを行いますので、現在お持ちの知識レベルからカリキュラムを作成いたします。さらにこちらの転職コースは無料で受講を始められて転職成功でそのまま卒業できるというとてもお得なコースとなっています。

既に知識のあるSEといっても転職は年齢が若いほど受かりやすいため、まずは無料体験レッスンで今の現状や理想の働き方について一緒に考えていきましょう。

まずは無料体験レッスンを予約する

書いた人

Sanshiro Wakizaka

Sanshiro Wakizaka

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

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

おすすめコンテンツ

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

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