我只有以下文件。
New Text Document - Copy (1)
New Text Document - Copy (2)
New Text Document - Copy (3)
New Text Document - Copy (4)
New Text Document - Copy (5)
除此之外,我还有类似的东西
Test1.pdf
test2.pdf
Test3.pdf
我的要求是找到文件名为“新文本文档”的最新文件
为了让你开始:
  ' need a FSO for folder access
  Dim oFS    : Set oFS    = CreateObject("Scripting.FileSystemObject")
  ' hold the file found (if any)
  Dim oFiFnd : Set oFiFnd = Nothing
  ' smallest possible number
  Dim nMax   : nMax       = 0
  ' define which files to consider
  Dim reFiNa : Set reFiNa = New RegExp
  reFiNa.Pattern = "^New Text Document - Copy \((\d+)\)$"
  Dim oFile, oMTS
  ' look at all files in folder
  For Each oFile In oFS.GetFolder("..\testdata\17405017").Files
      Set oMTS = reFiNa.Execute(oFile.Name)
      If 1 = oMTS.Count Then
         ' file confirms to pattern
         If nMax < CLng(oMTS(0).SubMatches(0)) Then
            ' largest nMax seen so far
            nMax       = CLng(oMTS(0).SubMatches(0))
            Set oFiFnd = oFile
         End If
      End If
  Next
  If oFiFnd Is Nothing Then
     ' search failed
     WScript.Echo "No file found."
  Else
     ' success
     WScript.Echo "found", oFiFnd.Path
  End If
更新 wrt 评论:
如果 RegExp 没有找到任何文件,则文件夹中没有像“新建文本文档 - 副本 (1)”这样的文件。您可以尝试@Ansgar 不那么严格的过滤器 - 只需查看文件名的前 17 个字符 - 或修改 .Pattern - 例如 ""^New Text Document - Copy ((\d+)).doc$" 如果您忘记了.doc 扩展名。
查看@Ansgar 的贡献也可以帮助您澄清您的规格:“最新”是指“最后修改的文件”还是“最高副本 (#)”?
枚举文件夹中的文件,如下所示:
Set fso = CreateObject("Scripting.FileSystemObject")
For Each f In fso.GetFolder("C:\some\where").Files
  WScript.Echo f.Name
Next
像这样检查文件的名称(用于LCase()使检查不区分大小写):
If LCase(Left(f.Name, 17)) = "new text document" Then
  'do stuff
End If
记住最近修改的文件,如下所示:
Set mostRecent = Nothing
...
If mostRecent Is Nothing Then
  Set mostRecent = f
ElseIf f.DateLastModified > mostRecent.DateLastModified Then
  Set mostRecent = f
End If