VBA100本ノック 21本目:バックアップファイルの削除
開いているブックの古いバックアップファイルを削除する問題です。
ツイートでの見やすさを考慮して、ブック・シート指定等を適宜省略しています。
出題
自身(ThisWorkbook)と同じフォルダに"BACKUP"フォルダがあります。
このフォルダ内に自身のバックアップが以下の名称で多数入っています。
ブック名_yyyymmddhhmm.xlsm
実行日を含め30日分だけ残し、古いファイルは削除してください。
※日付はファイル名で判断
VBA作成タイム
この下に頂いた回答へのリンクと解説を掲載しています。
途中まででも良いので、できるだけ自分でVBAを書いてみましょう。
他の人の回答および解説を見て、書いたVBAを見直してみましょう。
頂いた回答
解説
まずはDir関数をDo…Loopで順次処理するVBAは覚えておいた方が良いでしょう。
フォルダに関係ないファイルを間違って入れてしまっている場合もあるので、ブック名のチェックはしたいですね。
Sub VBA100_21_01()
Dim wb As Workbook
Dim delLastDay As String
Set wb = ThisWorkbook
delLastDay = Format(Date - 30, "yyyymmdd")
Dim sPath As String
Dim sFile As String
Dim sExt As String
sPath = wb.Path & "\BACKUP"
If Dir(sPath, vbDirectory) = "" Then Exit Sub
sExt = Mid(wb.Name, InStrRev(wb.Name, ".") + 1)
sFile = Left(wb.Name, InStrRev(wb.Name, ".") - 1)
Dim tFile As String
tFile = Dir(sPath & "\" & sFile & "_*." & sExt)
Do Until tFile = ""
If tFile Like sFile & "_############." & sExt Then
If Mid(tFile, InStrRev(tFile, "_") + 1, 8) <= delLastDay
Then
On Error Resume Next
Kill sPath & "\" & tFile
End If
End If
tFile = Dir()
Loop
End Sub
Killは読み取り専用は削除できないのでエラー対応を入れました。
FSOは読み取り専用も削除できますが、それでも削除できない場合もあります。
(ファイルを開いている等)
DirをFSOに書き換えたコードは記事補足に掲載しました。
※掲載VBAは少々テスト不足かもしれません。
補足
基本は、
tFile = Dir(パス)
Do Until tFile = ""
・・・
tFile = Dir()
Loop
この構造だけしっかり把握していれば問題ないでしょう。
Do...LoopがFor Each...Nextになっているだけで、基本構造は同じですね。
Sub VBA100_21_02()
Dim wb As Workbook
Dim delLastDay As String
Set wb = ThisWorkbook
delLastDay = Format(Date - 30, "yyyymmdd")
Dim sPath As String
Dim sFile As String
Dim sExt As String
Dim fso As Scripting.FileSystemObject
Set fso = CreateObject("Scripting.FileSystemObject")
sPath = wb.Path & "\BACKUP"
If Not fso.FolderExists(sPath) Then Exit Sub
sExt = fso.GetExtensionName(wb.Name)
sFile = fso.GetBaseName(wb.Name)
Dim tFile As File
For Each tFile In fso.GetFolder(sPath).files
If tFile.Name Like sFile & "_############." & sExt Then
If Mid(tFile.Name, InStrRev(tFile.Name, "_") + 1, 8) <=
delLastDay Then
On Error Resume Next
tFile.Delete Force:=True
End If
End If
Next
Set fso = Nothing
End Sub
文字列処理部分は、正規表現で処理する方法も考えられそうですが、
今回はかえってコードが長くなりそうなのでサンプルは書きませんでした。
サイト内関連ページ
同じテーマ「VBA100本ノック」の記事
18本目:名前定義の削除
19本目:図形のコピー
20本目:ブックのバックアップ
21本目:バックアップファイルの削除
22本目:FizzBuzz発展問題
23本目:シート構成の一致確認
24本目:全角英数のみ半角
25本目:マトリックス表をDB形式に変換
26本目:ファイル一覧作成
27本目:ハイパーリンクのURL
28本目:シートをブックに分割
新着記事NEW ・・・新着記事一覧を見る
抜けている数値を探せ|エクセル雑感(2022-07-01)
.Net FrameworkのSystem.Collectionsを利用|VBA技術解説(2022-06-29)
迷路ネコが影分身の術を体得したら…|エクセル雑感(2022-06-27)
迷路にネコが挑戦したら、どうなるかな…|エクセル雑感(2022-06-26)
サロゲートペアに対応した自作関数(Len,Left,Mid,Right)|エクセル雑感(2022-06-24)
「マクロの登録」で登録できないプロシージャーは?|エクセル雑感(2022-06-23)
オブジェクトのByRef、ByVal、Variant|エクセル雑感(2022-06-22)
コメントから特定形式の年月を取り出す|エクセル雑感(2022-06-19)
4,9を使わない連番作成|エクセル雑感(2022-06-17)
連番を折り返して出力|エクセル雑感(2022-06-16)
アクセスランキング ・・・ ランキング一覧を見る
1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.繰り返し処理(For Next)|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.Excelショートカットキー一覧|Excelリファレンス
7.マクロって何?VBAって何?|VBA入門
8.並べ替え(Sort)|VBA入門
9.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
10.エクセルVBAでのシート指定方法|VBA技術解説
- ホーム
- マクロVBA入門編
- VBA100本ノック
- 21本目:バックアップファイルの削除
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。