Import Data in Excel from a table created by a script in a WebPage

17,409

Try this

Sub Dow_HistoricalData()

    Dim xmlHttp As Object
    Dim TR_col As Object, TR As Object
    Dim TD_col As Object, TD As Object
    Dim row As Long, col As Long

    Set xmlHttp = CreateObject("MSXML2.XMLHTTP.6.0")
    xmlHttp.Open "GET", "http://www.investing.com/indices/us-30-historical-data", False
    xmlHttp.setRequestHeader "Content-Type", "text/xml"
    xmlHttp.send

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

    Dim tbl As Object
    Set tbl = html.getElementById("curr_table")

    row = 1
    col = 1

    Set TR_col = html.getelementsbytagname("TR")
    For Each TR In TR_col
        Set TD_col = TR.getelementsbytagname("TD")
        For Each TD In TD_col
            Cells(row, col) = TD.innerText
            col = col + 1
        Next
        col = 1
        row = row + 1
    Next
End Sub
Share:
17,409
MeSS83
Author by

MeSS83

Updated on June 05, 2022

Comments

  • MeSS83
    MeSS83 almost 2 years

    I am trying to create a macro that automatically connect to a web page and import in excel the data from a table. My problem is that Excel Query tool does not recognize the table, I think because it's create by a script in the page, and so I cannot use the standard way. For now, I am using this method:

    1. Copy the data into the clipboard
    2. Run a vba macro than gets the data from the clipboard and imports it in Excel

    However, I have more than 20 web pages to import every time and I would like a "standalone" macro which, given the url of the page, can import the data in excel.

    The webpage I am interested in is: http://www.investing.com/indices/us-30-historical-data I am using excel 2010

    Can anyone help me?

  • MeSS83
    MeSS83 over 10 years
    Thanks for your help Günter, I tried your answer but I get an error, however your idea is good: it is similar to solution proposed by Santos which works for my problem. Thanks a lot