微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

VBA 刮取表

如何解决VBA 刮取表

我想在 https://data.goaloong.net/1x2/ 上刮桌子

目前我正在使用此代码

Set http = New MSXML2.XMLHTTP
Set html = New HTMLDocument

url = "https://data.goaloong.net/1x2/"

http.Open "GET",url,False
http.setRequestHeader "Content-type","application/x-www-form-urlencoded"
http.send
    While http.readyState <> 4
        DoEvents
    Wend
html.body.innerHTML = http.responseText

   
With Sheets("table")

    Set HTMLAtab = html.getElementsByTagName("table")(0)

    For Each HTMLArow In HTMLAtab.Rows
        iRow = iRow + 1
        iCol = 0
        For Each HTMLAcel In HTMLArow.Cells
            iCol = iCol + 1
            Cells(iRow,iCol) = HTMLAcel.innerText
        Next HTMLAcel
    Next HTMLArow
          
End With

它没有做我需要的,我的目标是抓取 5 列的内容

enter image description here

我尝试修改代码

    .Cells(i,1) = html.getElementsByClassName("black-down f-white")(0).innerText
    .Cells(i,2) = html.getElementsByClassName("en")(0).getAttribute("data-tf")
    .Cells(i,3) = html.getElementsByClassName("team")(0).innerText
    .Cells(i,4) = html.getElementsByClassName("td")(2).getElementsByTagName("a")(0).innerText

尝试了各种方法都失败了。

我可以获得善意的支持吗?

解决方法

这是你想要的吗?

Sub TryThis()
    Dim HTMLDoc As New HTMLDocument
    Dim objTable As Object
    Dim lRow As Long
    Dim lngTable As Long
    Dim lngRow As Long
    Dim lngCol As Long
    Dim ActRw As Long
    Dim objIE As InternetExplorer
    Set objIE = New InternetExplorer
    Dim sht As Worksheet
    Dim LastColumn As Long

    objIE.Navigate "https://data.goaloong.net/1x2/"

    Do Until objIE.ReadyState = 4 And Not objIE.Busy
        DoEvents
    Loop
    
    Set sht = ThisWorkbook.Worksheets("Sheet1")
    
    Application.Wait (Now + TimeValue("0:00:01"))
    HTMLDoc.body.innerHTML = objIE.Document.body.innerHTML
    With HTMLDoc.body
        Set objTable = .getElementsByTagName("table")
        For lngTable = 0 To objTable.Length - 1
            For lngRow = 0 To objTable(lngTable).Rows.Length - 1
                For lngCol = 0 To objTable(lngTable).Rows(lngRow).Cells.Length - 1
                If lngCol = 0 Or lngCol = 1 Or lngCol = 2 Or lngCol = 3 Or lngCol = 11 Or lngCol = 12 Then
                    ThisWorkbook.Sheets("Sheet1").Cells(ActRw + lngRow + 1,lngCol + 1) = objTable(lngTable).Rows(lngRow).Cells(lngCol).innerText
                End If
                Next lngCol
            Next lngRow
            ActRw = ActRw + objTable(lngTable).Rows.Length + 1
        Next lngTable
    End With
    objIE.Quit
End Sub

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。