Excel如何用VBA实现,当A列某单元格如A1=“已完成”,则弹出对话框"B1还没填写完成日期"

a1b1a2b2a3b3........急用,在线等。。。说清楚点:当A1=“已完成”,但是B1为空时,则弹出对话框。请你们自己测试完之后再把答案贴出来。... a1 b1
a2 b2
a3 b3
........
急用,在线等。。。
说清楚点:当A1=“已完成”,但是B1为空时,则弹出对话框。
请你们自己测试完之后再把答案贴出来。
展开
 我来答
2724421
2012-09-16 · TA获得超过2491个赞
知道大有可为答主
回答量:1551
采纳率:71%
帮助的人:932万
展开全部
在工作表名称上点鼠标右键,选查看代码,粘贴以下代码到弹出的VBA编辑窗口.
代码如下:
Private Sub Worksheet_Change(ByVal Target As Range)
If Target.Column = 1 Then
With Target
If .Value = "已完成" And .Offset(0, 1) = "" Then
MsgBox .Offset(0, 1).Address(0, 0) & "还没填写完成日期!"
.Offset(0, 1).Select
End If
End With
End If
End Sub
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
小神狱1
2012-09-16 · TA获得超过614个赞
知道小有建树答主
回答量:542
采纳率:66%
帮助的人:300万
展开全部
Private Sub Worksheet_Change(ByVal Target As Range)
Dim i As Integer
i = Target.Row
If Cells(i, 1) = "已完成" And Cells(i, 2) = "" Then
MsgBox "单元格B" & i & "还没填写完成日期"
End If
End Sub

以上代码已测试通过
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
凝聚每分爱
2012-09-16 · TA获得超过485个赞
知道小有建树答主
回答量:913
采纳率:0%
帮助的人:537万
展开全部
Private Sub Worksheet_Change(ByVal Target As Range)
If [a1].Value = "已完成" And [b1] = "" Then MsgBox "B1还没填写完成日期"
End Sub
追问
谢谢,绝大部分是这个样子。但是我刚才没说太明白,如果A3值是“已完成”的话,则弹出“B3还没填写完成日期”。不是总是弹出“B1还没填写完成日期”。大侠,能再修整一下吗?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
朱仕平
2012-09-16 · 知道合伙人软件行家
朱仕平
知道合伙人软件行家
采纳数:7872 获赞数:29181
15年质量管理经验, 5年EXCEL培训经验, 目前专职EXCEL网络教育和企业培训

向TA提问 私信TA
展开全部
if range("A1")="已完成" and range("B1")="" then msgbox "B1还没有填写完成日期"
追问
不对
追答
那你就等个对的吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
q1293699286
2012-09-16
知道答主
回答量:48
采纳率:0%
帮助的人:14.6万
展开全部
那就放弃,删除。再开!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式