Excel中用VBA写一个判断并弹出对话框

可能要用到VBA,判断A1>A2时,弹出一个对话框,内容是警告,A1已大于A2,请确定继续?如果按“否”,就关闭这个Excel文件。如果关闭文件的代码比较复杂也可以... 可能要用到VBA,判断A1>A2时,弹出一个对话框,内容是警告,A1已大于A2,请确定继续?如果按“否”,就关闭这个Excel文件。如果关闭文件的代码比较复杂也可以不用,只要做一个确定就可以,点确定后什么事也不发生。PS:  A1和A2的数据是别的数据相加后的结果。 展开
 我来答
xiawei123
高粉答主

2019-10-28 · 每个回答都超有意思的
知道答主
回答量:1626
采纳率:100%
帮助的人:47.6万
展开全部

1、首先我们打开一个excel,这里建议使用office excel,因为wps的excel开发工具中的VBA是灰色的,还需要下载相关的插件,如下图所示:

2、接着我们在最上边的菜单栏中找到开发工具,然后找到Visual Basic,我们点击一下,就会出现一个新的页面,如下图所示:

3、当然出现新页面也有一个快捷键就是alt+f11,左边的sheet1、sheet2、sheet3都是你的工作表,我们可以随便点击一个进行操作,以sheet1为例如下图所示:

4、接着我们进行按钮代码的编写,在出来的菜单框中输入sub a(a是随便写的一个字母在这个位置你可以写任何东西)写好之后按回车键,就会自动出现相关的代码,如下图所示:

5、接着我们在两行代码的中间输入msgbox然后按一个空格键,在加上“”,我们在“”的中间输入你想要输入的内容,如hello,如下图所示:

6、写好上面的代码之后,按alt+f11回到主界面,然后在开发工具的下边找到插入,选中按钮,然后就会自动跳出宏,我们选中刚才那个代码也就是sheet1,如下图所示:

7、然后点击一下刚才的按钮就会弹出一个框,上面的内容就是之前写的hello,如果想删除这个按钮需要先用鼠标右键点击一下,然后按delete键,完成效果图。

2724421
推荐于2017-09-17 · TA获得超过2493个赞
知道大有可为答主
回答量:1551
采纳率:71%
帮助的人:951万
展开全部
ALT+F11进入VBA编辑,在左侧的列表里找到要判断的A1A2单元格所在的表双击,然后在右边的窗口里粘贴以下代码.并保存.
Private Sub Worksheet_Change(ByVal Target As Range)
If Target.Column = 1 Then
If Range("A1") > Range("A2") Then mya = MsgBox("A1已经大于A2,请确定是否继续?", vbYesNo, "警告")
If mya = 7 Then
Application.DisplayAlerts = False '所有的更改都不保存. 如果要保存,注释或删除这行
'ActiveWorkbook.Save '这行是保存工作表的,要使用这行代码请去掉代码前面的注释符号
Application.Quit
End If
End If
End Sub
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
太极健1969
2012-03-12 · TA获得超过9034个赞
知道大有可为答主
回答量:8668
采纳率:69%
帮助的人:3625万
展开全部
你的A1和A2是用公式计算的,应该使用Worksheet_Calculate事件完成,
不能用 Worksheet_Change事件完成,正确的代码如下
Private Sub Worksheet_Calculate()
Dim i
If Range("A1") > Range("A2") Then
i = MsgBox("A1已大于A2,是否继续?" & Chr(10) & "按否将退出系统!", 4, "警告")
If i = vbNo Then Application.Quit '按下否键,直接退出EXCEL系统
End If
End Sub
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
yetolee
2012-03-12 · TA获得超过580个赞
知道小有建树答主
回答量:175
采纳率:100%
帮助的人:43.3万
展开全部
在你想要判断A1A2所在表的标签上右键单击-查看代码,弹出VBA窗口,然后在右边的两个下拉列表框里,一个选择WORKSHEET,一个选择CHANGE
拷贝如下代码到SUB 和 END SUB 之间:
If Sheet1.Range("A1").Value > Sheet1.Range("A2").Value Then a = MsgBox("A1大于A2", vbOKCancel, "警告")
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
lb781201
2012-03-12 · TA获得超过702个赞
知道小有建树答主
回答量:567
采纳率:50%
帮助的人:143万
展开全部
继续时要干什么呢,
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式