7

我有一个 VBA 脚本,可以将工作表添加到大约 500 个 excel 文件中。我在运行 VBA 脚本和添加简单的工作表时没有遇到任何问题,但是当我尝试添加一个包含 VBA 脚本以及图形和按钮的工作表时,它会工作一段时间而不是冻结。

这是代码。我知道它没有错误处理 - 有什么建议可以解决这个问题,或者是什么导致 excel 冻结?

Sub FindOpenFiles()

Const ForReading = 1
Set oFSO = New FileSystemObject

Dim txtStream As TextStream

Dim FSO As Scripting.FileSystemObject, folder As Scripting.folder, file As Scripting.file, wb As Workbook, sh As Worksheet
Dim directory As String

'The path for the equipement list. - add the desired path for all equipement or desired value stream only.
Set txtStream = oFSO.OpenTextFile("O:\SiteServices\Maintenance\Maintenance Support Folder\Maintenance Department Information\HTML for Knowledgebase\Excel for Knowledgebase\Equipement paths-all.txt", ForReading)

Do Until txtStream.AtEndOfStream
    strNextLine = txtStream.ReadLine
    If strNextLine <> "" Then

    Set FSO = CreateObject("Scripting.FileSystemObject")
    Set folder = FSO.GetFolder(strNextLine)


    For Each file In folder.Files
        If Mid(file.Name, InStrRev(file.Name, ".") + 1) = "xls" Then
            Workbooks.Open strNextLine & Application.PathSeparator & file.Name

        Set wb = Workbooks("Equipment Further Documentation List.xls")
    For Each sh In Workbooks("Master File.xls").Worksheets
        sh.Copy After:=wb.Sheets(wb.Sheets.Count)
    Next sh

     ActiveWorkbook.Close SaveChanges:=True
     ActiveWorkbook.CheckCompatibility = False

        End If


    Next file
    End If

    Loop
txtStream.Close

End Sub
4

2 回答 2

9

所以,给你一些提示:

第一个。(根据评论)

作为第一行添加到您的 sub:Application.ScreenUpdating = false并在之前添加另一行End SubApplication.ScreenUpdating = true

第二。移动这条线(它正在设置常量参考):

Set wb = Workbooks("Equipment Further Documentation List.xls")

前:

Do Until txtStream.AtEndOfStream

第三个只是一个小费。

要查看子进程的进度,请添加以下行:

Application.StatusBar = file.Name

在这一行之后:

Workbooks.Open strNextLine & Application.PathSeparator & file.Name

End Sub另外添加此代码之前:

Application.StatusBar = false

结果,您可以在 Excel 应用程序的状态栏中看到当前正在处理的文件名。

请记住,处理 500 个文件必须非常耗时。

于 2013-08-09T10:19:18.207 回答
9

我终于解决了我的问题...

解决方案是添加一行代码:

Application.Wait (Now + TimeValue("0:00:01"))

行后:

sh.Copy After:=wb.Sheets(wb.Sheets.Count)

这允许有时间将工作表复制到新的 excel 文件中。

到目前为止,它一直像魅力一样工作。

我要感谢所有帮助我解决这个问题的人。

非常感谢。

于 2013-08-12T11:26:25.413 回答