利用Excel VBA代码编写日志

利用Excel VBA代码编写日志,查看表格操作修改记录。

在编辑excel表格时,如果能时时记录我们的操作过程,在需要查看修改过程时就很方便了。

以下是如何将代码添加到当前工作簿的步骤:

1. 打开Excel,并打开您的工作簿。
2. 按下"ALT + F11"打开VBA编辑器。
3. 在VBA编辑器中,找到您的工作簿项目(通常命名为VBAProject - 你的工作簿名称)。
4. 点击插入模块。
5. 在"这个工作簿"的代码窗口中,粘贴VBA代码。
6. 关闭VBA编辑器。

现在,您在修改相关工作表的单元格内容时,会自动记录日志在名为"日志"的工作表中。

Option Explicit

'在所有过程之前用Dim语句定义的变量r1是模块级变量,应模块中所有的过程都可以使用它
Dim r1 '定义一个模块级变量,用户保存单元格的数据
'第一个事件过程,用于记录被更改前单元格中保存的数据
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
If Target.Cells.Count <> 1 Then Exit Sub '选中多个单元格时退出程序
If Target.Formula = "" Then '根据选中单元格中保存的数据,确定给变量r1赋什么值
    r1 = "空"
Else
    r1 = Target.Text
End If
End Sub
'第二个事件过程,用于批注记录单元格修改前后的信息
Private Sub Worksheet_Change(ByVal Target As Range)
    If Target.Cells.Count <> 1 Then Exit Sub
    Dim r2        '定义变量保存单元格修改后的内容
    If Target.Formula = "" Then  '判断单元格是否被修改为空单元格
        r2 = "空"
    Else
        r2 = Target.Formula
    End If
    If r1 = r2 Then Exit Sub                          '如果单元格修改前后的内容一样则退出程序
    Dim r3                                                  '定义一个批注变量
    Dim r4                                                 '定义一个变量保存批注内容
    Set r3 = Target.Comment                   '将被修改单元格的批注赋给变量r3
    If r3 Is Nothing Then Target.AddComment       '如果单元格中没有批注则新建批注
    r4 = Target.Comment.Text                                  '将批注的内容保存到变量r4中
    '重新修改批注的内容=原批注内容+当前日期和时间+原内容+修改后的新内容
    Target.Comment.Text Text:=r4 & Chr(10) & Format(Now(), "yyyy-mm-dd hh:mm") & Chr(32) & "原内容:" & r1 & Chr(32) & "修改为:" & r2
    '根据批注内容自动调整批注大小
    Target.Comment.Shape.TextFrame.AutoSize = True
End Sub

但这个代码有BUG,就是粘贴复制修改时,需要选择性粘贴,只粘贴值,否则历史修改记录会被覆盖。

在上述基础上,

增加了修改时询问修改原因,并体现在批注里,适合小批量修改,大批量修改会出现弹窗反复问修改原因。 

Option Explicit

'在所有过程之前用Dim语句定义的变量r1是模块级变量,应模块中所有的过程都可以使用它
Dim r1 '定义一个模块级变量,用户保存单元格的数据
'第一个事件过程,用于记录被更改前单元格中保存的数据
Private Sub Worksheet_SelectionChange(ByVal Target As Range)
If Target.Cells.Count <> 1 Then Exit Sub '选中多个单元格时退出程序
If Target.Formula = "" Then '根据选中单元格中保存的数据,确定给变量r1赋什么值
    r1 = "空"
Else
    r1 = Target.Text
End If
End Sub
'第二个事件过程,用于批注记录单元格修改前后的信息
Private Sub Worksheet_Change(ByVal Target As Range)
    If Target.Cells.Count <> 1 Then Exit Sub
    Dim r2        '定义变量保存单元格修改后的内容
    If Target.Formula = "" Then  '判断单元格是否被修改为空单元格
        r2 = "空"
    Else
        r2 = Target.Formula
    End If
    If r1 = r2 Then Exit Sub                          '如果单元格修改前后的内容一样则退出程序
    Dim r3                                                  '定义一个批注变量
    Dim r4                                                 '定义一个变量保存批注内容
    Set r3 = Target.Comment                   '将被修改单元格的批注赋给变量r3
    If r3 Is Nothing Then Target.AddComment       '如果单元格中没有批注则新建批注
    Dim reason
    reason = InputBox("请输入修改原因:", "修改原因")
    r4 = Target.Comment.Text                                  '将批注的内容保存到变量r4中
    '重新修改批注的内容=原批注内容+当前日期和时间+原内容+修改后的新内容
    Target.Comment.Text Text:=r4 & Chr(10) & Format(Now(), "yyyy-mm-dd hh:mm") & Chr(32) & "原内容:" & r1 & Chr(32) & "修改为:" & r2 & "修改原因: " & reason
    '根据批注内容自动调整批注大小
    Target.Comment.Shape.TextFrame.AutoSize = True
End Sub

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Exceltodatabase是一个将Excel表格转换为数据库的工具。它可以将Excel表格中的数据进行解析和插入到数据库中,从而实现数据的长期存储和管理。使用Exceltodatabase工具可以节省大量手动输入数据的时间和精力,提高数据的准确性和完整性。 Exceltodatabase可以通过简单的配置实现与多种数据库的连接,如MySQL、Oracle、SQL Server等。用户只需要将Excel表格导入到Exceltodatabase工具中,然后指定要插入数据的数据库表和字段,即可完成数据的转换和插入。同时,Exceltodatabase还支持数据的更新和删除,用户可以根据自己的需求进行操作。 Exceltodatabase具有操作简单、安全稳定、数据转换快速等优点。它可以针对不同的数据表格和格式进行配置,支持多种数据类型的转换,如数字、日期、字符串、布尔值等。Exceltodatabase还提供了数据校验和日志记录功能,以保证数据的正确性和完整性。 总之,Exceltodatabase是一个功能强大的数据转换工具,它可以将Excel表格中的数据转换为可长期存储和管理的数据库数据,方便用户进行数据的管理和分析。 ### 回答2: Excel是一种常用的电子表格软件,它能够进行数值计算、数据分析、图表绘制等多种操作。而Database则是数据库的缩写,常用于存储、管理和处理大量数据。 Excel到Database的过程,就是将Excel中的数据导入到数据库进行统一的管理和处理。这个过程需要通过一些工具和技术来实现。 比如可以使用ODBC(Open Database Connectivity,开放数据库连接)技术来建立Excel和Database之间的连接,通过ODBC驱动程序可以将Excel表格中的数据导入到数据库中。 除此之外,还有一些第三方工具可供使用,例如ESF Database Migration Toolkit、DBConvert等。这些工具能够快速而方便地将Excel中的数据导入到任何支持ODBC的数据库中,包括SQL Server、MySQL、Oracle等。 Excel到Database的优点是能够方便地将Excel表格中的数据整合到数据库中,形成统一的数据集,方便数据管理和应用。同时,数据库中的数据也能够更好地进行分析和查询,帮助用户更快地获取数据信息。但同时,Excel的格式和数据结构与数据库不同,所以需要对导入的数据进行格式化和结构调整。 ### 回答3: Exceltodatabase是一种将Excel电子表格数据导入到数据库的操作。在传统的数据管理中,人们常常使用Excel表格来处理数据。但是,当数据量庞大,要进行统计分析或应用程序开发时,使用Excel已经不太实用了。因此,将Excel表格数据导入到数据库中,可以更好地管理数据,并且可以使用数据库提供的各种功能和工具对数据进行分析和处理。 Exceltodatabase的过程通常需要先将Excel数据转换成CSV或其他格式,然后再将数据导入到数据库中。这个过程可以通过使用一些开源的或商业的工具和软件来完成。其中,最常用的工具是Microsoft SQL Server Management Studio和MySQL Workbench,它们提供了快捷的导入数据功能。 使用Exceltodatabase可以让数据更具有可操作性和稳定性。通过使用数据库,可以提高数据的安全性和可靠性,并且可以方便地进行数据备份和还原。此外,通过使用数据库,还可以轻松地实现数据共享和访问的控制,从而更好地保护企业和个人的数据安全,更好地实现数据的价值。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值