ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 868|回复: 10

[求助] 求助 发现二义性的名称 Worksheet_Change(ByVal Target As Range) 求把两个代码合并

[复制链接]

TA的精华主题

TA的得分主题

发表于 2023-6-20 12:38 | 显示全部楼层 |阅读模式
本帖最后由 838225419 于 2023-6-20 16:41 编辑

Private Sub Worksheet_Change(ByVal Target As Range) '自动取客户信息
If Target.Address <> "$B$2" Then Exit Sub
Dim Arr, i&, d
Set d = CreateObject("Scripting.Dictionary")
S = Cells(2, 2)
bz = False
For i = 2 To Worksheets("客户资料").Cells(Rows.Count, 1).End(3).Row
    If Worksheets("客户资料").Cells(i, 2) = S Then
       bz = True
       Exit For
    End If
Next i
If Not bz Then
   [g2] = ""
   [j2] = ""
   [o2] = ""
   [d3] = ""
   [k3] = ""
   [a5] = ""
   [d5] = ""
   [f5] = ""
   [g5] = ""
   [h5] = ""
   [i5] = ""
   [j5] = ""
   [k5] = ""
   [n5] = ""
   [c8] = ""
   [g8] = ""
   [m8] = ""

   MsgBox "该车号的客户资料不存在"
Else
Arr = Sheet7.[a1].CurrentRegion
For i = 2 To UBound(Arr)
    If Arr(i, 2) = "" Then Exit For
    d(Arr(i, 2)) = i
Next
If [b2] = "" Then Exit Sub
'End If
i = d(Target.Value)
[g2] = Arr(i, 3): [j2] = Arr(i, 4): [o2] = Arr(i, 5): [c8] = Arr(i, 6): [g8] = Arr(i, 7): [m8] = Arr(i, 8)
End If
End Sub


Private Sub Worksheet_Change(ByVal Target As Range)‘单元格A1自动乘以5
On Error Resume Next
Dim Rng As Range
Application.EnableEvents = False '禁止触发事件
Set Rng = Range("a1") '你需要的单元格区域
If Intersect(Target, Rng) Is Nothing Then   '选择单元不在区内就退出
Application.EnableEvents = True '允许触发事件
Exit Sub
End If
On Error GoTo 100
Target.Value = Target.Value * 5
Application.ScreenUpdating = True
100:
If Err.Number = 13 Then
End If
Application.EnableEvents = True '允许触发事件
End Sub

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-6-20 14:43 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
这样试着合并了一下,但是下半部分不能触发事件,拜求各位大师
Private Sub Worksheet_Change(ByVal Target As Range) '自动取客户信息
On Error Resume Next
Dim Rng As Range
Application.EnableEvents = False '禁止触发事件
Set Rng = Range("j5") '你需要的单元格区域
If Intersect(Target, Rng) Is Nothing Then   '选择单元不在区内就退出
Application.EnableEvents = True '允许触发事件
Exit Sub
End If
On Error GoTo 100
Target.Value = Target.Value * 5
Application.ScreenUpdating = True
100:
If Err.Number = 13 Then
End If
'Application.EnableEvents = True

'从这里往下不能触发事件
If Target.Address <> "$B$2" Then Exit Sub
Dim Arr, i&, d
Set d = CreateObject("Scripting.Dictionary")
S = Cells(2, 2)
bz = False
For i = 2 To Worksheets("客户资料").Cells(Rows.Count, 1).End(3).Row
    If Worksheets("客户资料").Cells(i, 2) = S Then
       bz = True
       Exit For
    End If
Next i
If Not bz Then
   [g2] = ""
   [j2] = ""
   [o2] = ""
   [d3] = ""
   [k3] = ""
   [a5] = ""
   [d5] = ""
   [f5] = ""
   [g5] = ""
   [h5] = ""
   [i5] = ""
   [k5] = ""
   [n5] = ""
   [c8] = ""
   [g8] = ""
   [m8] = ""

   MsgBox "该车号的客户资料不存在"
Else
Arr = Sheet7.[a1].CurrentRegion
For i = 2 To UBound(Arr)
    If Arr(i, 2) = "" Then Exit For
    d(Arr(i, 2)) = i
Next
If [b2] = "" Then Exit Sub
'End If
i = d(Target.Value)
[g2] = Arr(i, 3): [j2] = Arr(i, 4): [o2] = Arr(i, 5): [c8] = Arr(i, 6): [g8] = Arr(i, 7): [m8] = Arr(i, 8)
End If

End Sub

TA的精华主题

TA的得分主题

发表于 2023-6-20 15:31 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
事件这个东西,知道怎么用以后,就自己慢慢调试,你设计的各种交互方式,别人通过代码不一定能看懂!慢慢调试吧,祝工作顺利!

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-6-20 16:11 | 显示全部楼层
WANT-T 发表于 2023-6-20 15:31
事件这个东西,知道怎么用以后,就自己慢慢调试,你设计的各种交互方式,别人通过代码不一定能看懂!慢慢调 ...

拜托大师

求助.rar

22.64 KB, 下载次数: 4

TA的精华主题

TA的得分主题

发表于 2023-6-20 17:32 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
不知道是不是你需要的。 求助.rar (20.84 KB, 下载次数: 7)

TA的精华主题

TA的得分主题

发表于 2023-6-20 18:17 | 显示全部楼层
本帖最后由 feilanga 于 2023-6-20 18:21 编辑

鼠标双击B2单元格

求助.rar

31.81 KB, 下载次数: 6

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-6-20 19:20 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 838225419 于 2023-6-21 08:02 编辑
feilanga 发表于 2023-6-20 18:17
鼠标双击B2单元格

谢谢,让您费心了
不是这样的要求,B2单元格输入后自动取客户信息,执行
Private Sub Worksheet_Change(ByVal Target As Range) '自动取客户信息
If Target.Address <> "$B$2" Then Exit Sub
Dim Arr, i&, d
Set d = CreateObject("Scripting.Dictionary")
S = Cells(2, 2)
bz = False
For i = 2 To Worksheets("客户资料").Cells(Rows.Count, 1).End(3).Row
    If Worksheets("客户资料").Cells(i, 2) = S Then
       bz = True
       Exit For
    End If
Next i
If Not bz Then
   MsgBox "该车号的客户资料不存在"
Else
Arr = Sheet7.[a1].CurrentRegion
For i = 2 To UBound(Arr)
    If Arr(i, 2) = "" Then Exit For
    d(Arr(i, 2)) = i
Next
If [b2] = "" Then Exit Sub
'End If
i = d(Target.Value)
[g2] = Arr(i, 3): [j2] = Arr(i, 4): [o2] = Arr(i, 5): [c8] = Arr(i, 6): [g8] = Arr(i, 7): [m8] = Arr(i, 8)
End If
End Sub
j5单元格输入数值后自动乘以5,执行
Private Sub Worksheet_Change(ByVal Target As Range)‘单元格A1自动乘以5
On Error Resume Next
Dim Rng As Range
Application.EnableEvents = False '禁止触发事件
Set Rng = Range("a1") '你需要的单元格区域
If Intersect(Target, Rng) Is Nothing Then   '选择单元不在区内就退出
Application.EnableEvents = True '允许触发事件
Exit Sub
End If
On Error GoTo 100
Target.Value = Target.Value * 5
Application.ScreenUpdating = True
100:
If Err.Number = 13 Then
End If
Application.EnableEvents = True '允许触发事件
End Sub
这两个程序运行的结果都要,只是如何去掉二定义提示,让程序正常运行(全并或修改)
非常感谢

TA的精华主题

TA的得分主题

发表于 2023-6-21 09:07 | 显示全部楼层
838225419 发表于 2023-6-20 19:20
谢谢,让您费心了
不是这样的要求,B2单元格输入后自动取客户信息,执行
Private Sub Worksheet_Change ...

不同的方式而已,目的达到不就行了

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-6-21 09:16 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
feilanga 发表于 2023-6-21 09:07
不同的方式而已,目的达到不就行了

但是:电话:O2,卡号M8 如何变为数字,拜求大师

TA的精华主题

TA的得分主题

发表于 2023-6-21 10:47 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
838225419 发表于 2023-6-21 09:16
但是:电话:O2,卡号M8 如何变为数字,拜求大师

说清楚点 不懂你的意思
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-16 15:50 , Processed in 0.047585 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表