学以致用——使用VBA实现创建新记录时自动添加时间戳(Add timestamp when adding new record in Excel)

今天又实现了一个“梦寐以求”的功能:为Excel中创建的新记录自动添加时间戳。

虽然这是个简单需求,但是我却等了很久。

虽然代码不难,但是调试却花了我一个多小时,在此分享给所有有缘之人。

方法:

1. 首先要确保当前Excel文件的保存格式支持VBA(使用.xlsm或.xlsb格式)

2. 在VBE(在Excel中可使用快捷键ALT+F11打开VBE,即Visual Basic Editor)中,选择目标工作表,双击该工作表,将下图中黄色加亮的部分分别修改为“Worksheet”和"Change"。


3. 在代码区添加以下代码,注意,.Offset(0,5)表示要将时间戳添加到第6列,大家可根据实际需要进行修改。

Private Sub Worksheet_Change(ByVal Target As Range)
    With Target
        If .Count = 1 Then
            If .Column = 1 Then
                Application.EnableEvents = False
                .Offset(0, 5).Value = IIf(.Value = "", "", Now)
                UsedRange.Borders.LineStyle = xlContinuous
                Application.EnableEvents = True
            End If
        End If
    End With
End Sub

效果:


评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值