Run Multiple Private Sub Worksheet_Change(ByVal Target As Range)

SaraWitch

Active Member
Joined
Sep 29, 2015
Messages
378
Office Version
  1. 365
Platform
  1. Windows
Hello peeps,

I'm trying to find a general rule of thumb when wanting to run more than one Private Sub Worksheet_Change(ByVal Target As Range) routines. I have tried a variety of ways, but nothing is working for me.

My two codes are...

Jump to target cell when data entered:
VBA Code:
Private Sub Worksheet_Change(ByVal Target As Range)
  If Intersect(Range("X7:X10000"), Target) Is Nothing Then Exit Sub
  Target.Offset(0, -8).Select
End Sub

Allow more than one option in DVL:
VBA Code:
Private Sub Worksheet_Change(ByVal Target As Range)
  Dim Value_Old As String
  Dim Value_New As String
  If Target.Count > 1 Then Exit Sub
  If Target.Value = "" Then Exit Sub
  If Not Intersect(Target, ActiveSheet.Range("H6:H100000")) Is Nothing Then
  Application.EnableEvents = False
  Value_New = Target.Value
  On Error Resume Next
  Application.Undo
  On Error GoTo 0
  Value_Old = Target.Value
  If InStr(Value_Old, Value_New) Then
  If InStr(Value_Old, ",") Then
  If InStr(Value_Old, ", " & Value_New) Then
  Target.Value = Replace(Value_Old, ", " & Value_New, "")
  Else
  Target.Value = Replace(Value_Old, Value_New & ", ", "")
End If
 Else
  Target.Value = ""
End If
 Else
  If Value_Old = "" Then
  Target.Value = Value_New
 Else
  If Value_New = "" Then
  Target.Value = ""
 Else
  If InStr(Target.Value, Value_New) = 0 Then
  Target.Value = Value_Old & ", " & Value_New
End If
End If
End If
End If
  Application.EnableEvents = True
 Else
Exit Sub
End If
End Sub

Any help would be appreciated :)
 

Excel Facts

Show numbers in thousands?
Use a custom number format of #,##0,K. Each comma after the final 0 will divide the displayed number by another thousand
You can add your first one to the second one, as long as you just change how it works a little. That section is in red.
Rich (BB code):
Private Sub Worksheet_Change(ByVal Target As Range)

  Dim Value_Old As String
  Dim Value_New As String

  If Not Intersect(Range("X7:X10000"), Target) Is Nothing Then
      Target.Offset(0, -8).Select
  End If

  If Target.Count > 1 Then Exit Sub
  If Target.Value = "" Then Exit Sub
  If Not Intersect(Target, ActiveSheet.Range("H6:H100000")) Is Nothing Then
  Application.EnableEvents = False
  Value_New = Target.Value
  On Error Resume Next
  Application.Undo
  On Error GoTo 0
  Value_Old = Target.Value
  If InStr(Value_Old, Value_New) Then
  If InStr(Value_Old, ",") Then
  If InStr(Value_Old, ", " & Value_New) Then
  Target.Value = Replace(Value_Old, ", " & Value_New, "")
  Else
  Target.Value = Replace(Value_Old, Value_New & ", ", "")
End If
 Else
  Target.Value = ""
End If
 Else
  If Value_Old = "" Then
  Target.Value = Value_New
 Else
  If Value_New = "" Then
  Target.Value = ""
 Else
  If InStr(Target.Value, Value_New) = 0 Then
  Target.Value = Value_Old & ", " & Value_New
End If
End If
End If
End If
  Application.EnableEvents = True
 Else
Exit Sub
End If

End Sub
 
Upvote 0
Solution
That's grand; thank you so much, Joe! :biggrin: I think I tried every variation except this one (my coding knowledge is fairly limited unfortunately).

So, there's not really a general rule of thumb combining routines as it depends on the coding then...? I was hoping there would be an easy "ADD" type function! 😆
 
Upvote 0
The rule of thumb of this:
- You cannot have multiple procedures in the same module with the same name
- If you have multiple things you need to happen in an Event Procedure, they need to all be combined into one single procedure. You can usually do this by "stacking" the code inside the procedure.
- Be aware of any "Exit Sub" sections in your code! If you exit the sub in your first block of code, you will never get to the second block! So you need to change the logic of that statement.

In your code, you had the first IF that said:
"If the update is NOT in a certain range, exit the sub"
So, we needed to change the logic to say:
"If the update IS in a certain range, then do these steps."

Hope that helps!
 
Upvote 1
You are welcome.
Glad I was able to help!
 
Upvote 0

Forum statistics

Threads
1,225,424
Messages
6,184,907
Members
453,264
Latest member
AdriLand

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top