为了解决这个问题我,选用了EXCEL97中的事件,就是如果使用Private Sub Worksheet_Change(ByVal Target As Range)事件,这个事件就是在WORKSHEET,如果发生改变以后就让它去执行如下代码!
Private Sub Worksheet_Change(ByVal Target As Range)
'Designed by liuzheng
'http://grwy.online.ha.cn/vba_excel97/
my = Target.Column
myadd = Target.Address
With Range(myadd).Offset(0, 1)
If Range(myadd).Address = "$A$1" Then Exit Sub
Application.EnableEvents = False
If my = 1 Then
If Target <> "" Then
.NumberFormatLocal = "@"
.Value = Now
Else
If b <> vbCancel Then .Value = ""
End If
Else
Application.EnableEvents = True
Exit Sub
End If
End With
Application.EnableEvents = True
End Sub
在代码中,我使用了"NOW"函数,这个函数是EXCEL中的内置函数,它的意思就是得出当前系统的时钟时间,如:1/3/2000 11:22:35 AM,但是直接在单元格中输入NOW的值,它只显示:1/3/2000 11:22 AM不能精确到秒,如何使它精确到秒呢?我采用了如下语句".NumberFormatLocal = "@"", 让NOW函数显示为文本!怎么样很简单吧!本例中如果我们在单元格中输入"=NOW()"你会看到单元格中将显示为:1/3/2000 11:22 AM,但如果下一次您打开工作表之后,所有带有"=NOW()"的单元格将都改为您打开工作簿的时间,所以只能将值付给单元格,而不能只输入NOW函数公式!
而ENABLEEVENTS属性是使得,指定对象能触发事件,它是个 Boolean 类型。
希望上述代码能够使您举一反三,方便自己的工作为准!编写VBA程序以方便工作而准,如果为了编程而编程就失去了编程的意义!
最后我也希望各位VBA高手,写出更多更好的代码,以便我们的工作!
延伸阅读
文章来源于领测软件测试网 https://www.ltesting.net/