求Excel VBA代码才用XMLHTTP的方法提取一网页内表格?

网页地址为http://f9.eastmoney.com/soft/gp13.php?code=00000202,求完整vba代码,要求才用XMLHTTP的方法提取该表格... 网页地址为http://f9.eastmoney.com/soft/gp13.php?code=00000202,求完整vba代码,要求才用XMLHTTP的方法提取该表格。最好对代码作个注释。 展开
 我来答
鄙人_焉哉乎也
2013-11-08 · TA获得超过166个赞
知道小有建树答主
回答量:89
采纳率:0%
帮助的人:129万
展开全部

分析好久才弄出来的,经实测成功,望采纳...

Sub test()
    Dim strUrl$, objHttp As Object, strRtn, arrRtn, i%, j%
    strUrl = "http://f9.eastmoney.com/soft/gp13.php?code=00000202"
    Set objHttp = CreateObject("msxml2.xmlhttp")
    objHttp.Open "GET", strUrl, 0
    objHttp.send
    While objHttp.readystate <> 4
        DoEvents
    Wend
    Cells.Clear     '清除表格内容
    Rows(2).NumberFormatLocal = "@"     '第二行设置为文本格式
    '取 "<table" 之后的内容
    strRtn = Split(objHttp.responsetext, "<table", -1, vbTextCompare)(1)
    '以 "<tr>" 作为分隔符把数据分为行数组
    strRtn = Split(strRtn, "<tr>", -1, vbTextCompare)
    For i = 0 To UBound(strRtn)     '行循环
        '各个字段以 "<span>" 分隔
        arrRtn = Split(strRtn(i), "<span>", -1, vbTextCompare)
        For j = 1 To UBound(arrRtn) '列循环
            '取"</span>"之前的内容,并且把"&nbsp;"替换为空,然后输出到表格里
            Cells(i + 1, j + 1) = Replace(Split(arrRtn(j), "</span>", -1, vbTextCompare)(0) _
                , "&nbsp;", "", 1, -1, vbTextCompare)
        Next j
    Next i
    Set objHttp = Nothing
    MsgBox "done..."
End Sub

woshimafanren
2013-11-07 · TA获得超过296个赞
知道小有建树答主
回答量:580
采纳率:78%
帮助的人:97.2万
展开全部
不用VBA导出吧,在右面就有导出EXCEL啊
追问
我知道,但是我需要的不仅仅是这一个页面,还有很多类似界面,要用XMLHTTP的方法来获取。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式