返回列表 上一主題 發帖

[發問] 請教此程序為何錯誤?

[發問] 請教此程序為何錯誤?

請教此程序為何錯誤? Book1.zip (11.51 KB)

流程控制好, 還是可以把效能影響降低的

TOP

本帖最後由 t8899 於 2015-4-5 21:25 編輯
以下是用 XMLHTTP 抓出來的內容
可以看到有欄位名稱, 但抓不到數值
那個網頁的數值是用 javascript 事後補 ...
bobomi 發表於 2015-4-5 20:39

這種5秒5秒一直更新,只有javascript 才做的到??
用IE 抓資料,速度太慢........太消眊資源...............再找看看有無其他法!
我目前是用GBKEE兄寫的,稍微做部份修改如下
Set Ie = CreateObject("InternetExplorer.Application")
   Ie.Navigate "http://mis.twse.com.tw/stock/group.jsp?ex=tse&ind=TIDX#STATISTICS"
    Dim timeie
    timeie = DateAdd("s", 10, Now())
    Do While Ie.Busy Or Ie.ReadyState <> 4
    DoEvents
           If timeie < Now() Then
        MsgBoxTest 0, "無法連接網站,請重新執行", "提示訊息", vbSystemModal, 0, 2000
        Ie.Quit
            Exit Sub
             End If
            Loop
-----------------------------------------------------------------------------
    Dim i As Integer, S As Integer, k As Integer, j As Integer
     Dim Element
    Set Element = Ie.document.getelementsbytagname("table")
    With Sheets("sheet5")
     '  .Range("C1:C17").ClearContents
        For S = 2 To 3                    '已找出網頁的table內容在 0-3 中
            For i = 0 To Element(S).Rows.Length - 1
                k = k + 1
              '  For j = 0 To Element(S).Rows(i).Cells.Length - 1   '資料的欄位共6位
                j = 2
                    .Cells(k, j + 1) = Element(S).Rows(i).Cells(j).innerText
           '     Next
            Next
        Next
    End With
    Set Element = Nothing

TOP

以下是用 XMLHTTP 抓出來的內容
可以看到有欄位名稱, 但抓不到數值
那個網頁的數值是用 javascript 事後補上來的
你用 IE 開那個網頁-> IE菜單 -> 另存新檔 ---> 存到 xxx.htm ---> 再把  xxx.htm 用 IE 打開 ---> 只見欄位, 看不見數值

整體市場         股票         基金         認購權證         認售權證
總委買數量        -        -        -        -        -
總委買筆數        -        -        -        -        -
總委賣數量        -        -        -        -        -
總委賣筆數        -        -        -        -        -
漲停委買數量        -        -        -        -        -
漲停委買筆數        -        -        -        -        -
漲停委賣數量        -        -        -        -        -
漲停委賣筆數        -        -        -        -        -
跌停委買數量        -        -        -        -        -
跌停委買筆數        -        -        -        -        -
跌停委賣數量        -        -        -        -        -
跌停委賣筆數        -        -        -        -        -

TOP

那個網址盤後測試是否一樣 ie 停留10分會造成excel整個速度慢下來
還是只有盤中才會 lag ?
bobomi 發表於 2015-4-5 19:39

這網頁每5秒會自動update 一次,所以我連上一次然後開個副程式每隔5秒-60秒抓一次
每隔n秒抓一次,並不會造成lag, 是IE 連上後10分鐘才會lag, 從工作管理員看ie佔記憶體,時間越久記憶體佔越大
盤後我沒測試
  這網頁不一定要借用IE來抓,應該還有其他方法 像 XMLHTTP......... 不知您會嗎?可否賜教?

TOP

那個網址盤後測試是否一樣 ie 停留10分會造成excel整個速度慢下來
還是只有盤中才會 lag ?

TOP

本帖最後由 t8899 於 2015-4-5 19:04 編輯
你可以用  菜單的搜尋   
搜尋 If Time >  + TIMEB Then   
就可以找到
bobomi 發表於 2015-4-5 18:53

抱歉,經常看電腦螢幕,尤其在寫程式不知不覺一直注視.......加速眼睛老化..年紀也大了........所以看不到.........
現在找到了

TOP

你可以用  菜單的搜尋   
搜尋 If Time > [b2] + TIMEB Then   
就可以找到

TOP

本帖最後由 t8899 於 2015-4-5 18:23 編輯
If Time >  + TIMEB Then

你的  前面沒有 . 啊

此時的  變成 Sheet2. = 空值

加上 . 就好了 ...
bobomi 發表於 2015-4-5 15:00

我看了好幾次,還是沒有看到,謝謝!

TOP

我有指明啊 !
它不是 private
With Workbooks("book1.xls").Sheets("sheet1")
.Range("B2") = TimeVal ...
t8899 發表於 2015-4-5 14:54



If Time > [b2] + TIMEB Then

你的 [b2] 前面沒有 . 啊

此時的 [b2] 變成 Sheet2.[b2] = 空值

[b2] 加上 . 就好了

TOP

        靜思自在 : 一個人不怕錯,就怕不改過,改過並不難。
返回列表 上一主題