VBA宏可以批量更新同一位置的多个文件

时间:2013-07-04 04:34:36

标签: excel vba

对此非常新,请帮助。我试图批量更新静态文件夹位置的文件,一个文件夹中的许多文件。

我想做的是

  • 在Excel 2010中运行VBA宏以转到网络位置文件夹
  • 打开文件夹中的第一个文件。
  • 取消保护工作簿,工作表调用另一个marco来运行更改
  • 然后保护工作表关闭文件
  • 然后转到文件夹中的下一个文件,直到所有文件都得到纠正。

我创建了marco进行更改,这称为“编辑”

文件类型是xlsm,工作簿和工作表受密码保护我如何自动运行宏来转到网络位置并串行打开每个文件,取消保护,调用宏,然后重新保护文档关闭文件并转到下一个文件,直到它们全部更新。

Sub Auto_open_change()

Dim WrkBook As Workbook
Dim StrFileName As String
Dim FileLocnStr As String
Dim LAARNmeWrkbk As String

PERNmeWrkbk = ThisWorkbook.Name
StrFileName = "*.xlsx"
FileLocnStr = ThisWorkbook.Path
Workbooks.Open (FileLocnStr & "\" & StrFileName)
Workbooks(StrFileName).Activate

With Application.FindFile
SearchSubFolders = False
LookIn = "Network location"
Filename = "*.xlsm"
If .Execute > 0 Then
    Debug.Print "There were " & .FoundFiles.Count & " file(s) found."
    For i = 1 To .FoundFiles.Count
        WrkBook = Workbooks.Open(Filename:=.FoundFiles(i))
        WrkBook.Worksheets(1).Select
        ThisWorkbook.Worksheets(1).Cells(DestinationRange) = WrkBook.Worksheets(1).Cells(SourceRange).Value
    Next i
Else
    Debug.Print "There were no files found."

End If

我设法取消保护文件更新并重新保护文件,但无法从网络位置获取文件。

1 个答案:

答案 0 :(得分:1)

我正在使用Excel 07,它不允许Application.FindFile,所以我无法测试它。但是,我认为问题可能是您需要Set变量Wrkbook,而不仅仅是分配它。

更改

WrkBook = Workbooks.Open(Filename:=.FoundFiles(i))

Set WrkBook = Workbooks.Open(Filename:=.FoundFiles(i))

让我知道结果如何!