gpt4 book ai didi

excel - 来自 www.eppraisal.com 的 VBA 网页抓取

转载 作者:行者123 更新时间:2023-12-04 22:07:32 25 4
gpt4 key购买 nike

我需要从 获取数据www.eppraisal.com

所以我写了以下代码,但不幸的是它不起作用:

Public Function GetEppraisalValuation()
Dim strURL As String
Dim strLocationURL As String

Dim strEppraisalValue As String
Dim strEppraisalHighLow As String

Dim lngStartPointer As Long
Dim lngEndPointer As Long

'strAddressForWeb1 = "4189 E LAFAYETTE AVE"
'strAddressForWeb2 = "GILBERT, AZ 85298"
strURL = "http://www.eppraisal.com/home-values/property/1122-e-loyola-dr-tempe-az-85282-42382460/"

Set zHttp = CreateObject("WinHttp.WinHttpRequest.5.1")
zHttp.Open "GET", strURL, False
zHttp.Option(iWinHttpRequestOption_EnableRedirects) = False
zHttp.setRequestHeader "Accept", "text/html, application/xhtml+xml, */*"
zHttp.setRequestHeader "Accept-Encoding", "gzip, deflate"
zHttp.setRequestHeader "Accept-Language", "en-us"
zHttp.setRequestHeader "User-Agent", "Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Trident/5.0)"
zHttp.setRequestHeader "Referer", strURL
zHttp.setRequestHeader "Connection", "Keep-Alive"
zHttp.setRequestHeader "Host", "www.eppraisal.com"
'zHttp.setRequestHeader "Cookie", "ASP.NET_SessionId=" & SessionID
'zHttp.setRequestHeader "Cookie", ".ASPXAUTH=" & ASPXAUTH

zHttp.send

If zHttp.Status <> 302 Then
Exit Function
End If

strLocationURL = zHttp.getResponseHeader("Location")

strURL = "http://www.eppraisal.com" & strLocationURL
'DeleteUrlCacheEntry (strURL)

zHttp.Open "GET", strURL, False
zHttp.Option(iWinHttpRequestOption_EnableRedirects) = True
zHttp.setRequestHeader "Accept", "text/html, application/xhtml+xml, */*"
'zHttp.setRequestHeader "Accept-Encoding", "gzip, deflate"
zHttp.setRequestHeader "Accept-Language", "en-us"
zHttp.setRequestHeader "User-Agent", "Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Trident/5.0)"
zHttp.setRequestHeader "Referer", strURL
zHttp.setRequestHeader "Connection", "Keep-Alive"
zHttp.setRequestHeader "Host", "www.eppraisal.com"
'zHttp.setRequestHeader "Cookie", "ASP.NET_SessionId=" & SessionID
'zHttp.setRequestHeader "Cookie", ".ASPXAUTH=" & ASPXAUTH

zHttp.send

If zHttp.Status <> 200 Then
Exit Function
End If

ieDom.body.innerHTML = zHttp.responseText
For Each ieInp In ieDom.getElementsByTagName("p")
If ieInp.className = "ColorAccent6 FloatLeft FontSizeK Margin0" Then
strEppraisalValue = ieInp.innerText
Exit For
End If
Next

For Each ieInp In ieDom.getElementsByTagName("p")
If ieInp.className = "FontSizeA FloatRight Margin0 DisplayNone HighLow" Then
strEppraisalHighLow = ieInp.innerText
Exit For
End If
Next

wrkshtPI.Range("C1").Offset(intRowOffset, 0) = strEppraisalValue

lngStartPointer = InStr(1, strEppraisalHighLow, "Low:")
If lngStartPointer = 0 Then
Exit Function
End If
lngEndPointer = InStr(1, strEppraisalHighLow, Chr(10))
If lngEndPointer = 0 Then
Exit Function
End If
wrkshtPI.Range("D1").Offset(intRowOffset, 0) = Trim(Mid(strEppraisalHighLow, lngStartPointer + 4, lngEndPointer - (lngStartPointer + 5)))
wrkshtPI.Range("E1").Offset(intRowOffset, 0) = Trim(Mid(strEppraisalHighLow, lngEndPointer + 7, Len(strEppraisalHighLow) - (lngEndPointer + 7)))
End Function

zHTTP 的状态码不是 302,这是无效的。此外,我在 ResponseBody 中得到了一些垃圾值。

我在下面的屏幕截图中突出显示了我想要获取的 3 个数字。 enter image description here

有人可以建议到底出了什么问题吗?

谢谢。

最佳答案

干得好

 Const URl As String = "http://www.eppraisal.com/home-values/property_lookup_eppraisal?a=1122%20E%20Loyola%20Dr&z=85282&propid=42382460"
Sub xmlHttp()
Dim xmlHttp As Object
Set xmlHttp = CreateObject("MSXML2.XMLHTTP")
xmlHttp.Open "GET", URl, False
xmlHttp.setRequestHeader "Content-Type", "text/xml"
xmlHttp.send


Dim html As Object
Set html = CreateObject("htmlfile")
html.body.innerHTML = xmlHttp.ResponseText
Debug.Print html.body.innerHTML
End Sub

立即窗口上的输出
<P style="LINE-HEIGHT: 1.2em" class="ColorAccent6 FontBold FontSizeM Margin0 Padding0">$148,305</P>
<P style="LINE-HEIGHT: 1.1em" class="FontSizeA Margin0 DisplayNone HighLow">Low: $126,059 <BR>High: $170,550</P>

关于excel - 来自 www.eppraisal.com 的 VBA 网页抓取,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17825577/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com