返回列表 上一主題 發帖

[發問] 依次記錄各股殖利率

[發問] 依次記錄各股殖利率

請問版上高手:在小弟的附檔中,由”常用代碼”的工作表雙擊代碼即可於”估價”的工作表C5取得該股殖利率,若小弟想由”常用代碼”的工作表雙擊A2代碼於”估價”的工作表取得A2的殖利率紀錄於”常用代碼”工作表中的C2,接著雙擊A3代碼於”估價”的工作表取得A3的殖利率紀錄於”常用代碼”工作表中的C3,依次直到A27,請問這巨集或VBA該如何寫?謝謝。

殖利率.rar (11.13 KB)

年齡不小,但我很想學

回復 22# stillfish00
雖然因為才疏學淺不太了解stillfish00大的解釋,但仍非常感謝您,謝謝
年齡不小,但我很想學

TOP

回復 19# bhsm
我沒2003無法測,當然理論上要一致
但2003到2010 , Excel背後Calculate的機制也改變很多了
有這種不同也不無可能。
畢竟哪些程式碼會觸發哪些event , 這部分在Excel說明中我也沒看到...

總之我是覺得Event中代碼前後,用Application.EnableEvents控制開關,
應該是不會錯的好習慣啦(雖然我也常忘記)
表達不清、題意不明確、沒附檔案格式、沒有討論問題的態度~~~~~~以上愛莫能助。

TOP

回復 20# stillfish00
感謝stillfish00大,照您的程式修改後已可以使用了,謹在此謝謝您及GBKEE大.
年齡不小,但我很想學

TOP

回復 17# bhsm
可以改這樣測測看
  1. Private Sub Worksheet_Calculate()
  2.     Application.EnableEvents = False
  3.     On Error GoTo EXIT_THIS
  4.    
  5.     If
  6.    
  7.     ........
  8.    
  9.     End If

  10. EXIT_THIS:
  11.     If Err.Number > 0 Then
  12.         MsgBox Err.Description
  13.         Stop
  14.         Resume  'F8 goto error line
  15.     End If
  16.     Application.EnableEvents = True
  17. End Sub
複製代碼
表達不清、題意不明確、沒附檔案格式、沒有討論問題的態度~~~~~~以上愛莫能助。

TOP

回復 18# stillfish00
感謝stillfish00大,小弟納悶的是為何EXCEL2003使用上沒問題,但轉成2010時,卻會造成堆疊空間不足,理論上若有程式一直不斷循環觸發,那在2003是不是也應該發生呢?還請您解惑,謝謝
年齡不小,但我很想學

TOP

回復 15# bhsm
個人經驗供參考:
可以檢查你的另外檔案的工作表/活頁簿用到的Event
常見堆疊空間不足的原因"之一"
可能是Event中某些程式碼行為又觸發了其他Event,然後一直不斷循環觸發...

如果是這原因,可在Event事件中適當設定Application.EnableEvents
暫時避免觸發其他event,最後再還原。
表達不清、題意不明確、沒附檔案格式、沒有討論問題的態度~~~~~~以上愛莫能助。

TOP

本帖最後由 bhsm 於 2015-4-24 17:17 編輯

回復 16# GBKEE
向GBKEE大回報,
1.雙擊代碼後會出現圖1

2.按下F8後出現圖2,此時資料未帶入所需位置

3.接著再按一次F8,出現圖3,此時檢視資料都已帶入,但此時須關閉VBA視窗,並停止偵錯,EXCEL才可繼續使用

4.重複1.之動作
年齡不小,但我很想學

TOP

回復 15# bhsm
堆疊空間不足,Stop 後按下 F8 看看程式如何執行
  1. Stop
  2.       Sheet3.Rng.Resize(, 4).Value = Array([c5].Text, [F3].Text, [F4].Text, [C8].Text)
  3.       
複製代碼
感恩的心......(在麻辣家族討論區.用心學習會有進步的)
但資源無限,後援有限,  一天1元的贊助,人人有能力.

TOP

回復  bhsm
GBKEE 發表於 2015-4-23 14:48

GBKEE大您好:
我把您教的這個VBA套用在公司的檔案上時,用2003操作都沒問題,但把該檔轉成2010時,操作上卻會發生"執行階段錯誤"28"  堆疊空間不足,當我按下偵錯時,程式會指向
"Sheet28.Rng.Resize(, 4) = Array([L5].Text, [L6].Text, [C14].Text, [B13].Text)",如果在昨天傳給您的150423.rar檔案轉成2010時,操作沒問題,但套用到公司另外檔案時卻會
發生堆疊空間不足,請問應該修改哪裡來排除問題,謝謝
年齡不小,但我很想學

TOP

        靜思自在 : 小事不做、大事難成。
返回列表 上一主題