data:image/s3,"s3://crabby-images/d1a07/d1a077c1cfb9098cb296825057e8c44424152a6d" alt=""
下記図のように指定フォルダーの下にあるサブフォルダーから最新のサブフォルダーパスを抽出する方法を紹介します。
data:image/s3,"s3://crabby-images/0ad9f/0ad9fb96f563026403ab75e27f637912c12be9d7" alt=""
data:image/s3,"s3://crabby-images/0ad9f/0ad9fb96f563026403ab75e27f637912c12be9d7" alt=""
data:image/s3,"s3://crabby-images/0ad9f/0ad9fb96f563026403ab75e27f637912c12be9d7" alt=""
フォルダー名ではなく最新更新日時で抽出したいときに便利だよ!
コピペして使ってね!
data:image/s3,"s3://crabby-images/9581c/9581ca0f591b47731b1f2c2f052c0e645bb714cb" alt=""
data:image/s3,"s3://crabby-images/9581c/9581ca0f591b47731b1f2c2f052c0e645bb714cb" alt=""
data:image/s3,"s3://crabby-images/2b9f8/2b9f8d9f49ed6796f37e77455ffd67fad39c3629" alt=""
data:image/s3,"s3://crabby-images/2b9f8/2b9f8d9f49ed6796f37e77455ffd67fad39c3629" alt=""
目次
指定フォルダーから最新フォルダーを自動抽出 サンプル
任意のフォルダー下の最新のサブフォルダのパスを抽出したい
今回はファイルシステムオブジェクト(FileSystemObject = FSO)を活用して、フォルダーを選択し、その中にある最新サブフォルダーの最新パスを抽出するサンプルになります。
Sub NewestFolder_PickUp()
Application.ScreenUpdating = False
Dim Folder_Path As String
MsgBox "最新フォルダパスを自動抽出するよ!フォルダを選択してね( ー`дー´)"
With Application.FileDialog(msoFileDialogFolderPicker)
If .Show = True Then
Folder_Path = .SelectedItems(1)
Else
MsgBox "フォルダが正しく選択されなかったので終了します(#^ω^)"
Exit Sub
End If
End With
Dim FSO As Object, Folder As Object, Fl As Object
Set FSO = CreateObject("Scripting.FIleSystemObject")
Set Folder = FSO.GetFolder(Folder_Path)
Dim NewestFolder As String
Dim MaxTime As Date
For Each Fl In Folder.SubFolders
If Fl.DateLastModified > MaxTime Then
MaxTime = Fl.DateLastModified
NewestFolder = Fl.PATH
End If
Next
MsgBox "最新フォルダーのPathは " & vbCrLf & NewestFolder & vbCrLf & "です(^o^)"
End Sub
FSOを使用するにはその下準備として「Microsoft Scripting Runtime」への参照設定を行う必要があります。
1.ツールをクリック
2.[参照設定]をクリック
3.参照可能なライブラリファイルから「Microsoft Scripting Runtime」をクリックしチェックマークをつける
4.[OK]をクリック
data:image/s3,"s3://crabby-images/db517/db517ed06cbe9aa0d182c90656c411a3c60af8a8" alt=""
data:image/s3,"s3://crabby-images/db517/db517ed06cbe9aa0d182c90656c411a3c60af8a8" alt=""
data:image/s3,"s3://crabby-images/c2cc8/c2cc8a12e5b500f0ce4ec78da5f203ebdde5b491" alt=""
data:image/s3,"s3://crabby-images/c2cc8/c2cc8a12e5b500f0ce4ec78da5f203ebdde5b491" alt=""
まとめ
このサンプルを活用いただけると、サブフォルダー名に関わらず最新更新日時のパスを抽出することができます。
この記事がミス撲滅や生産性向上につながるととても嬉しいです。
VBA初級から抜け出すための知恵と、実務で活用できるスキルが学べる1冊です!激しくオススメ!
data:image/s3,"s3://crabby-images/948ee/948ee638de15a15f8d3531da6c18e573e6277056" alt=""
data:image/s3,"s3://crabby-images/948ee/948ee638de15a15f8d3531da6c18e573e6277056" alt=""
コメント