循环不认识 [英] Loop does not recognize Do
本文介绍了循环不认识的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我一直在编辑/编写这个代码,将多个工作簿合并成一个。
但是我得到一个循环没有做编译错误。可能的重复不会说出了什么问题,只给出一个新的代码,所以这不是我的问题的答案,而是解决方案。
I have been editing/writing this code to merge multiple workbooks into one. However I get a "Loop without Do" compile error. The possible duplicate does not say what went wrong, only gives a new code, so that is not a answer to my question but a solution.
Sub MergeAllWorkbooks()
Dim SummarySheet As Worksheet
Dim FolderPath As String
Dim NRow As Long
Dim OCol As Long
Dim FileName As String
Dim WorkBk As Workbook
Dim SourceRangeCult As Range
Dim DestRangeCult As Range
Dim SourceRangeYield As Range
Dim DestRangeYield As Range
Dim SourceRangeLoc As Range
Dim DestRangeLoc As Range
Dim SourceRangeDRipe As Range
Dim DestRangeDRipe As Range
Dim LastRow As Integer
Dim LastColumn As Integer
Dim col As Integer
Set SummarySheet = Workbooks.Add(xlWBATWorksheet).Worksheets(1)
FolderPath = "M:\My Documents\MSC Thesis\United Kingdom\Winter Barley\Merge excel\"
NRow = 1
OCol = 2
OColD = OCol + 48
FileName = Dir(FolderPath & "*.xl*")
Do While FileName <> ""
Set WorkBk = Workbooks.Open(FolderPath & FileName)
SummarySheet.Range("A" & NRow).Value = FileName
LastRow = ActiveSheet.UsedRange.Rows.Count
LastColumn = ActiveSheet.UsedRange.Columns.Count
For col = 2 To 49
Set SourceRangeLoc = WorkBk.Worksheets(1).Range("A1:A" & LastRow)
Set DestRangeLoc = SummarySheet.Range("C" & NRow)
Set DestRangeLoc = DestRange.Resize(SourceRangeLoc.Rows.Count, 1)
Set SourceRangeCult = WorkBk.Worksheets(1).Range(OCol & "1:" & OCol & "1")
Set DestRangeCult = SummarySheet.Range("B" & NRow)
Set DestRangeCult = DestRange.Resize(SourceRangeLoc.Rows.Count, 1)
Set SourceRangeYield = WorkBk.Worksheets(1).Range(OCol & "2:" & OCol & LastRow)
Set DestRangeYield = SummarySheet.Range("D" & NRow)
Set DestRangeYield = DestRange.Resize(SourceRangeLoc.Rows.Count, 1)
Set SourceRangeDRipe = WorkBk.Worksheets(1).Range(OColD & "2:" & OColD & LastRow)
Set DestRangeDRipe = SummarySheet.Range("E" & NRow)
Set DestRangeDRipe = DestRange.Resize(SourceRangeLoc.Rows.Count, 1)
DestRangeCult.Value = SourceRangeCult.Value
Exit For
NRow = NRow + DestRange.Rows.Count
OCol = OCol + 1
WorkBk.Close savechanges:=False
FileName = Dir()
Loop
SummarySheet.Columns.AutoFit
End Sub
推荐答案
c $ c>对于循环没有结束表达式。 退出
用于突破循环 - 指出正常结束,只需使用 Next
。
Your inner For
Loop doesn't have a closing expression. Exit For
is used to break out of a loop - to state the regular ending, simply use Next
.
这篇关于循环不认识的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文