EXCEL使用VBA的问题

Subauto_open()a=Range("C86")DimxAsDoubleDimyAsDoubleDimminAsDoubleDimmxAsDoubleDimmyA... Sub auto_open()
a = Range("C86")
Dim x As Double
Dim y As Double
Dim min As Double
Dim mx As Double
Dim my As Double
min = 2000
mx = 2000
my = 1
For x = 1 To 2000
For y = 1 To 2000
If Abs(x / y - a) < min Then
min = Abs(x / y - a)
mx = x
my = y
End If
Next
Next
Range("F58").Value = mx
Range("F60").Value = my

End Sub

这是我的代码,这段代码执行的结果是当单元格C86的值改变后需要存盘重新启动EXSEL才计算F58和F60,我想让C86的值改变后马上就计算,而不要存盘再启动,能实现吗?怎么改?
我想实现的效果就想是单元格内输入公式那样.shuhua0715你说的那个意思是将Sub auto_open()换成Private Sub Worksheet_SelectionChange(ByVal Target As Range)吗?还在原来的位置更换就行吗?不好用啊!
展开
 我来答
xautwuyi
2010-03-22 · TA获得超过404个赞
知道小有建树答主
回答量:570
采纳率:0%
帮助的人:367万
展开全部
你应该是为了方便操作吧。

1. 创建一个按钮,将这段代码放到按钮点击事件中执行。
这样每次修改C86后,点一下按钮即可
2. 在单元格的单击或双击事件中激活代码
HuaGeG
2010-03-22 · TA获得超过7708个赞
知道大有可为答主
回答量:8038
采纳率:26%
帮助的人:2203万
展开全部
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
***********
*********
******
End Sub
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式