excel宏运行时出现运行时错误1004,应用程序定义或对象定义错误,请大神指点!!!

PrivateSubWorksheet_Change(ByValTargetAsRange)Diml_row,l_columnAsLongi_row=Target.Row... Private Sub Worksheet_Change(ByVal Target As Range)
Dim l_row, l_column As Long
i_row = Target.Row
i_column = Target.Column
If Target.Count = 1 Then
If Target.Column = 10 And Target.Offset(0, -2) <> "" Then
Cells(Target.Row, 17) = Target.Offset(0, -2)
ElseIf Target.Column = 10 And Target.Offset(0, -2) = "" Then
Cells(Target.Row, 17) = Date
ElseIf Target.Column = 8 And Target.Offset(0, 9) <> "" Then
Cells(Target.Row, 17) = ""
End If
End If
End Sub

提示If Target.Column = 10 And Target.Offset(0, -2) <> "" Then这一句有误。
宏能正常运行,但是每当我在第一列和第二列单元格中输入或删除时,就会出现上面的错误提示,而在其他列输入删除时没有提示。我是小白,看不出来,请各路大神指教!!!
展开
 我来答
阳光上的桥
2019-05-19 · 知道合伙人软件行家
阳光上的桥
知道合伙人软件行家
采纳数:21423 获赞数:65812
网盘是个好东东,可以对话和传文件

向TA提问 私信TA
展开全部

Target.Offset(0, -2)表示鼠标点击位置的左边第二列,当点A、B列的时候就会报错,因为他们的左边出界了。

尽管前面有Column=10的并且条件,但是VBA不进行布尔短路,因此其他列点鼠标的时候任然会去查看左边第二列。

解决的办法是使用嵌套的If判定,我简单修改如下,可能你还需要适当微调:

Private Sub Worksheet_Change(ByVal Target As Range)
    Dim l_row As Long, l_column As Long
    i_row = Target.Row
    i_column = Target.Column
    If Target.Count = 1 Then
        If i_column = 10 Then
            If Target.Offset(0, -2) <> "" Then
                Cells(i_row, 17) = Target.Offset(0, -2)
            Else
                Cells(i_row, 17) = Date
            End If
        ElseIf i_column = 8 Then
            If Target.Offset(0, 9) <> "" Then Cells(i_row, 17) = ""
        End If
    End If
End Sub

变量定义均需要指定类型,程序代码适当进行缩减,尽量使用已经赋值的简单变量

wwj805
2019-05-19 · TA获得超过1412个赞
知道小有建树答主
回答量:692
采纳率:55%
帮助的人:393万
展开全部
Target.Offset(0, -2) 表示当前单元格向左移动两列后的对应单元格,你在第一列和第二列操作时,再左移两列,就没有单元格了。
追问
谢谢!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式