0
此代码有效,但不一致。通常,它失败在这条线:Excel VBA提取Xero报告
For Each objElement In htmlDoc.GetElementsByTagName("td")
下面是代码:
Dim AppIE
Dim htmlDoc
Dim nRow As Integer
Dim nColNum As Integer
Dim objElement
Dim nColCount As Integer
Set AppIE = CreateObject("InternetExplorer.Application")
AppIE.Visible = True 'login may be required
AppIE.Navigate myString 'from clipboard
While AppIE.Busy 'wait for IE to open
DoEvents
Wend
While AppIE.ReadyState <> 4 'wait for login
DoEvents
Wend
While AppIE.Busy 'pause put in by Donald
DoEvents
Wend
Set htmlDoc = AppIE.Document
nRow = 0
nColCount = 0
nColNum = 0
For Each objElement In htmlDoc.GetElementsByTagName("td")
'If IsNull(objElement.classname) And IsNull(objElement.innertext) Then
'Else
If objElement.classname = "RowHeader2 MenuLeft" Then
nColCount = nColCount + 1
Cells(nRow, nColCount).Value = objElement.innertext
Else
If nColCount >= 1 Then
nColNum = nColNum + 1
Cells(nRow, nColNum).Value = objElement.innertext
If nColNum = nColCount Then
nColNum = 0
nRow = nRow + 1
End If
If Len(objElement.classname) = 0 Then
nColNum = 0
nRow = nRow + 1
End If
Else
nRow = nRow + 1
Cells(nRow, 1).Value = objElement.innertext
End If
End If
'End If
Next
AppIE.Visible = False
MsgBox "Done"
AppIE.Quit
Set AppIE = Nothing
当它失败时,它是第一个元素还是其他元素?你得到什么错误代码? –
Hi Rich。当它失败时,它会立即在第一个元素上失败 - 不会产生错误,它必须是它找到零个元素并立即退出For循环。 –