8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

使用 VBA 循环遍历文件夹中的文件?

zest16 1月前

83 0

我想使用 Excel 2010 中的 vba 循环遍历目录的文件。在循环中,我需要:文件名和文件格式化的日期。我已编写了以下代码...

Excel 2010 中的循环遍历目录的文件

在循环中,我需要:

  • 文件名,以及
  • 文件格式化的日期。

我编写了以下代码,如果文件夹中的文件不超过 50 个,则运行良好,否则速度会非常慢(我需要它处理包含超过 10000 个文件的文件夹)。此代码的唯一问题是查找操作 file.name 需要花费大量时间。

代码可以运行但是速度太慢了(每 100 个文件需要 15 秒):

Sub LoopThroughFiles()
   Dim MyObj As Object, MySource As Object, file As Variant
   Set MySource = MyObj.GetFolder("c:\testfolder\")
   For Each file In MySource.Files
      If InStr(file.name, "test") > 0 Then
         MsgBox "found"
         Exit Sub
      End If
   Next file
End Sub

问题解决:

  1. 我的问题已通过以下解决方案解决,使用 Dir 特定方式(15000 个文件需要 20 秒)并使用命令检查时间戳 FileDateTime .
  2. 考虑到下面的另一个答案,20 秒减少到少于 1 秒。
帖子版权声明 1、本帖标题:使用 VBA 循环遍历文件夹中的文件?
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由zest16在本站《file》版块原创发布, 转载请注明出处!
最新回复 (0)
  • Dir 当我处理来自其他文件夹的文件时,功能很容易失去焦点。

    我使用该组件获得了更好的结果 FileSystemObject .

    完整示例如下:

    http://www.xl-central.com/list-files-fso.html

    不要忘记在 Visual Basic 编辑器中设置对 Microsoft Scripting Runtime (通过使用工具 > 引用)

    尝试一下!

返回
作者最近主题: