Я попытался построить цикл, который отбрасывает определенные данные, когда он соответствует критериям, а затем публикует результаты в моем ' Основной "лист.Мой цикл vba возвращает все правильные данные, когда я перехожу, но когда я запускаю макрос, это не
К сожалению, при запуске макроса он не отбрасывает все данные.
Однако, это, на мой взгляд, очень странно, когда вы проходите через это.
В любой момент кода нет сообщений об ошибке, и код проходит весь путь, если вы выполните или просто запустите макрос.
Я разместил мой код ниже:
Sub Loop_Data()
'BR stands for Blank Row
Dim i As Integer, j As Integer, k As Integer, m As Integer, BRMAin As Integer, BRData As Integer, BRPhysNot As Integer, _
SearchRange As Range, strID As String, ExtEnd As Integer, FindRow As Range
BRMAin = Sheets("Main").Cells(Rows.Count, "W").End(xlUp).Row
BRData = Sheets("Data").Cells(Rows.Count, "A").End(xlUp).Row
BRPhysNot = Sheets("PhysNot").Cells(Rows.Count, "A").End(xlUp).Row
Set SearchRange = Sheets("Data").Range("A3:A" & BRData)
Sheets("CoData").Activate
'assign j for number of rows (units) and i to start at 6 (column J) and end at 21
For j = 2 To 48
i = 35
Do Until i = 52
'criteria
If Cells(j, i - 1).Interior.Color <> RGB(51, 51, 51) And Cells(j, i - 1) > 0 And Cells(j, i).Interior.Color = RGB(51, 51, 51) Then
'find duration o
m = 0
Do While Cells(j, i + m).Interior.Color = RGB(51, 51, 51)
m = m + 1
Loop
'check that the flagged is definitely matching criteria
If Cells(j, i + m) = 0 Then
'set string ID as the string of uni & period to find in the helper column of Data sheet
'set k as row which that occurs in
strID = Cells(1, i) & Cells(j, 3)
Set FindRow = SearchRange.Find(strID)
k = FindRow.Row
'Pull back data into main sheet
ThisWorkbook.Sheets("Main").Range("X" & BRMAin + 1) = Sheets("Data").Cells(k, 8)
ThisWorkbook.Sheets("Main").Range("V" & BRMAin + 1) = Sheets("Data").Cells(k, 4)
ThisWorkbook.Sheets("Main").Range("W" & BRMAin + 1) = Sheets("Data").Cells(k, 2)
ThisWorkbook.Sheets("Main").Range("Y" & BRMAin + 1) = m
ThisWorkbook.Sheets("Main").Range("Z" & BRMAin + 1) = Sheets("CoData").Cells(1, i)
End If
End If
i = i + 1
Loop
Next j
End Sub
Я читал, что [добавить сон может помочь] (https://www.mrexcel.com/forum/excel-questions/412764-macro-works-stepping-through-but-not-when -i-вводного первенствовать-2003-a.html # post2070738). Это было для них (частично). –
Что происходит, когда вы запускаете его без прохождения? Не может ли он что-либо сделать, или он выполняет половину работы, а затем останавливается? – jsheeran
Является ли это задержкой в поиске, делает ли 'workheetfunction.match' вам что-нибудь. попробуйте после findRow 'debug.print" J is "& j &" k is "& k &" strid is "& strid', см., если' K' не работает где-то. –