返回列表 上一主題 發帖

[發問] 如何將Worksheet_Change的變數宣告,改成在一般模組使用?

[發問] 如何將Worksheet_Change的變數宣告,改成在一般模組使用?

本帖最後由 jackson7015 於 2014-4-29 09:12 編輯

請問各位前輩
如何將下面Worksheet中的變數宣告,改成在模組的一般巨集就好了?

因為做了其他巨集要使用
但是只要有更動到Worksheet的單格儲存格,就會啟動此宣告

想請教前輩們,如何將以下變數宣告,改成一般模組的巨集使用且只作用在[a5]儲存格就好了
感謝不吝指教~
  1. Private Sub Worksheet_Change(ByVal Target As Range)
  2. Dim A As Range, Rng As Range
  3. If Target.Column = 1 Then
  4. With Sheets("綜合資料庫")
  5. For i = 1 To .UsedRange.Rows.Count
  6.    Set A = .UsedRange.Rows(i).Find(Target)
  7.    If Not A Is Nothing Then
  8.      If Rng Is Nothing Then
  9.      Set Rng = .UsedRange.Rows(i)
  10.      Else
  11.      Set Rng = Union(Rng, .UsedRange.Rows(i))
  12.      End If
  13.     End If
  14. Next
  15. End With
  16. End If
  17. Application.EnableEvents = False
  18.     If Not Rng Is Nothing Then
  19.     Rng.Copy: Target.Offset(, 1).PasteSpecial 3
  20.     Else
  21.     Target.Offset(, 1).Resize(, 50) = ""
  22.     End If
  23. Application.EnableEvents = True
  24.     MsgBox "查詢結束"
  25. End Sub
複製代碼

回復 2# GBKEE

GBKEE版大您好;
請問是否只新增一組此巨集將原本的變數宣告導入,然後再將您的宣告放到SHEET1(查詢用表單)的Worksheet_Change內?

但是我如此做會宣告錯誤
不曉得是哪個步驟錯誤了?

感謝GBKEE版大的回覆

TOP

回復 4# GBKEE

GBKEE版大,對不起,沒有陳述清楚需要的部分

宣告在Worksheet_Change的部分,會下列的巨集啟動,儲存格只要一變動,就會自動啟動宣告部分
  1. Sub 清除查詢表格()
  2. ' 清除查詢表格 巨集
  3. With Sheets("查詢用表單")
  4.     Range("$B5:$BR301").Select
  5.     Selection.ClearContents
  6.     Range("A5").Select
  7.     End With
  8. End Sub
複製代碼
我想改成只用巨集手動去搜索,這樣才不會有儲存格有變動的時候,就啟動Worksheet_Change的部分
是否能將Worksheet_Change程式碼,改成在Module1模組的編程
自己研究了幾天,還是不會把在Worksheet_Change的編寫,改成在Module1模組中...

自己資質愚鈍,想麻煩GBKEE版大能否幫忙修正編寫
感謝不盡..

TOP

回復 6# GBKEE

GBKEE版大,想再次麻煩一下
因為我的表達好像有問題..

我想直接將1樓的程式碼
不在Worksheet內編寫,而是編寫在Module

現在的問題是只要一改變儲存格[A5]的內容,就會自動執行1樓的程式碼
我想改成手動方式執行,手動執行 Sub 查詢表格() 巨集才會執行

不曉得這樣解,GBKEE版大是否比較好理解
感謝您再次的回覆

TOP

回復  GBKEE
附上檔案,再請GBKEE版大看看
參考資料庫.rar (992.52 KB)

TOP

回復 6# GBKEE

檔案已附上,再請GBKEE大大看看是否可行

今天研究了半天還是不會改...

TOP

本帖最後由 jackson7015 於 2014-5-8 09:09 編輯

回復 10# GBKEE
感謝GBKEE版大的幫忙
可以正常運作了

自己所需要的部分是下面的那些程式碼,刪除了些不需要的部分
vb的程式碼都不會編寫,都只會一些簡單的一般區編寫
感謝版大的無心付出

想再請問版大MsgBox的問題
如果我想在下列的程式碼中插入一則"查詢中"的MsgBox,但是會在搜尋結束後,MsgBox視窗會自動消除
那種MsgBox語法該怎麼編寫 ?

查詢了站上資料,找不太到MsgBox自動結束的相關資料
  1. Sub 查詢資料()
  2.     Dim F As Range, AD As String, Rng As Range, xRng As Range
  3.     Set xRng = Sheets("查詢用表單").[A5]
  4.     With Sheets("綜合資料庫").UsedRange
  5.         Set F = .Find(xRng, LOOKAT:=xlPart)
  6.         If Not F Is Nothing Then AD = F.Address
  7.         Do While Not F Is Nothing
  8.             If Rng Is Nothing Then
  9.                 Set Rng = .Rows(F.Row)
  10.             Else
  11.                 Set Rng = Union(Rng, .Rows(F.Row))
  12.             End If
  13.             Set F = .FindNext(F)
  14.             If F.Address = AD Then Exit Do
  15.         Loop
  16.     End With
  17.     If Not Rng Is Nothing Then
  18.         Rng.Copy xRng.Offset(, 1)
  19.         MsgBox "查詢結束"
  20.     Else
  21.         xRng.Offset(, 1).Resize(, 50) = ""
  22.     End If
  23. End Sub
複製代碼

TOP

回復 12# GBKEE
感謝GBKEE版大

此程式碼是給它設定秒數,就會再指定時間內 Aoto Close

不過我想詢問的是
開始執行程式碼的時候會出現MsgBox ,然後程式碼執行結束後MsgBox 也跟著消失

以這篇的10樓程式碼為例:
執行程式碼>出現MsgBox "查詢中">查詢結束後>MsgBox 消失
這問題和主題沒有一致,我想還是另開個主題比較合適?

在此由衷的感謝GBKEE版大無私的教導

TOP

回復 14# GBKEE
感謝GBKEE版大的回應

程式執行起來更有系統,也更美觀了
想請問版大
因為有時候搜尋件數會有達到數十件,甚至百件
而大略看了您的編寫,每次會延遲1秒做迴圈
這樣會有很長時間在等待迴圈的運算

是否有直接以MsgBox顯示"搜尋中"
然後搜尋結束後MsgBox框架就會自動消失的編寫方式 ?(不是延遲秒數)

非常感謝GBKEE版大還特別寫了TextBox的程式

TOP

回復 16# GBKEE
感謝GBKEE版大的回覆

原來停留的秒數是程式原本的設定啊,還以為是Application.Wait Time 的關係,想說這編碼好像不能寫小於1秒

這篇討論獲益良多
使用到的相關編碼還有很多不明白的,再慢慢地消化
由衷感謝GBKEE大大的付出,謝謝~

TOP

        靜思自在 : 人的眼睛長在前面,只看到別人的缺點,絲毫看不到自己的缺點。
返回列表 上一主題