web-dev-qa-db-ja.com

マクロ-フォルダー内のすべてのファイルを開く

指定したフォルダー内のすべてのファイルを開き、次のコードを取得したい

Sub OpenFiles()
Dim MyFolder As String
Dim MyFile As String
MyFolder = "\\ILAFILESERVER\Public\Documents\Renewable Energy\FiTs\1 Planning
           Department\Marks Tracker\Quality Control Reports"
MyFile = Dir(MyFolder & "\*.xlsx")
Do While MyFile <> ""
Workbooks.Open Filename:=MyFolder & "\" & MyFile
Loop
End Sub

私が抱えている問題は、フォルダー内の最初のファイルを繰り返し開こうとするだけで、先に進まないということです。誰でも助けてもらえますか、私はVBAの初心者で、本当に助けてもらえます。すべてが.xlsx形式の約30のレポートを開こうとしています。事前に感謝します。

14
Ross McLaughlin

loopの直前にこの行を追加する必要があります

    MyFile = Dir
Loop
26
Siddharth Rout

ループチェックステートメントでLen(StrFile) > 0を使用できます!

Sub openMyfile()

    Dim Source As String
    Dim StrFile As String

    'do not forget last backslash in source directory.
    Source = "E:\Planning\03\"
    StrFile = Dir(Source)

    Do While Len(StrFile) > 0                        
        Workbooks.Open Filename:=Source & StrFile
        StrFile = Dir()
    Loop
End Sub
2
josef

以下のコードを試してください:

Sub opendfiles()

Dim myfile As Variant
Dim counter As Integer
Dim path As String

myfolder = "D:\temp\"
ChDir myfolder
myfile = Application.GetOpenFilename(, , , , True)
counter = 1
If IsNumeric(myfile) = True Then
    MsgBox "No files selected"
End If
While counter <= UBound(myfile)
    path = myfile(counter)
    Workbooks.Open path
    counter = counter + 1
Wend

End Sub
1
Satish