用Excel VBA代码实现去重录入某字段内容

2023-10-27 23:30

本文主要是介绍用Excel VBA代码实现去重录入某字段内容,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

功能描述


图1 信息录入表单示意图


图2 用于录入信息的自定义窗体示意图

如图所示,在样表中用自定义窗体录入信息,要求:

1、日期自动设为当前日期,不用手动录入;

2、车牌号不能重复录入(之前重复的不作考虑),否则停止运行,并弹出消息;


要点分析

1、实现功能1要点

  禁用日期文本框,当前日期用Format(Date, "yyyy/m/d")获取

2、实现功能2要点

(1)查找车牌号:用for-each遍历,若找到,则转至(2);否则转至(4)

(2)中断循环,给出提示:用MsgBox;

(3)再选中该车牌号文本:用text.SelStart和text.SelLength;转到(6)

-------------------

(4)在新的一行录入信息:新行标用Range("A65536").End(xlUp).Row+1

(5)录入文本框内容清理;

(6)退出录入过程;


其他组件

1、主窗体fmMain

在打开Excel或选中Sheet2时显示该主页面:


2、查询窗体fmQuery

查询车牌号,结果列在Sheet3中:


完整代码

1、录入窗体fmImput代码:

Option Explicit
Private Sub cmdSave_Click()'非空验证If txtDate.Value = "" Or txtUserName.Value = "" Or txtUserCarNo.Value = "" _Or txtUserTel.Value = "" Or txtUserCarType.Value = "" ThenMsgBox "信息录入不完整,请补充完整后再保存!", vbCritical, "录入错误"txtUserName.SetFocusExit SubEnd If'车牌号去重验证Dim carID As String:        carID = txtUserCarNo.TextDim REPEATED As Boolean:    REPEATED = FalseDim cell As RangeFor Each cell In Sheet1.Columns("B:B").CellsIf cell.Value = carID ThenREPEATED = TrueExit ForEnd IfNext'未通过验证If REPEATED ThenMsgBox "您当前录入车牌号[" + carID + "]已被其他用户录入,请重新输入!", vbCritical, "车牌号重复"REPEATED = FalsetxtUserCarNo.SetFocustxtUserCarNo.SelStart = 0txtUserCarNo.SelLength = Len(carID)Exit SubEnd If'通过验证Application.ScreenUpdating = FalseSheet1.ActivateDim newRow As IntegernewRow = Sheet1.Range("A65536").End(xlUp).Row + 1Cells(newRow, 1).Value = txtDate.TextCells(newRow, 2).Value = txtUserCarNo.ValueCells(newRow, 3).Value = txtUserName.ValueCells(newRow, 4).Value = txtUserTel.ValueCells(newRow, 5).Value = txtUserCarType.ValueMsgBox "用户信息保存成功,单击【确定】继续!", vbInformation, "操作成功"txtUserCarNo.Value = ""txtUserName.Value = ""txtUserTel.Value = ""txtUserCarType.Value = ""Application.ScreenUpdating = True
End SubPrivate Sub cmdBack_Click()fmInput.HideSheet2.Activate
End SubPrivate Sub UserForm_Initialize()txtDate.Text = Format(Date, "yyyy/m/d")txtDate.Enabled = FalsetxtUserCarNo.Value = ""txtUserName.Value = ""txtUserTel.Value = ""txtUserCarType.Value = ""
End Sub


2、主窗体fmMain代码:

Private Sub cmdAddUserInfo_Click()Sheet1.ActivatefmMain.HidefmInput.Show
End SubPrivate Sub cmdQuery_Click()Sheet3.ActivatefmMain.HidefmQuery.Show
End Sub


3、查询车牌窗体fmQuery代码:

Private Sub cmdQuery_Click()'非空验证If txtTargetCarID.Value = "" ThenMsgBox "要查询的车牌号错误或为空值", vbCritical, "输入错误"txtTargetCarID.SetFocusExit SubEnd IfApplication.ScreenUpdating = FalseSheet1.Activate'获取数据源区域和查询条件Dim carID As String:    carID = txtTargetCarID.TextDim lastRow As Integer: lastRow = Range("A65536").End(xlUp).RowSet sourceArea = Range(Cells(2, 1), Cells(lastRow, 5))'获取匹配记录总数Dim cell As RangeDim resultCount As IntegerFor Each cell In Sheet1.Range("B2:B" & lastRow)If cell.Value = carID ThenresultCount = resultCount + 1End IfNext'无记录则退出查询Dim info As StringIf resultCount = 0 Theninfo = "操作失败!" & vbCrLf & "没有找到车牌号为[ " & carID & " ]的用户信息,请核对车牌号后重试!"MsgBox info, vbCritical, "查询结果"txtTargetCarID.SetFocustxtTargetCarID.SelStart = 0txtTargetCarID.SelLength = Len(carID)Exit SubEnd If'有记录则循环输出查询结果Dim resultArea()ReDim resultArea(1 To resultCount, 1 To 5)Dim sourceRow As IntegerDim resultRow As IntegerFor sourceRow = 1 To sourceArea.Rows.CountIf sourceArea.Item(sourceRow, 2).Value = carID ThenresultRow = resultRow + 1For i = 1 To 5resultArea(resultRow, i) = sourceArea(sourceRow, i)Next ii = 0End IfNextSheet3.ActivateRange("A2:E65536").ClearContentsRange("A2:E5").Resize(resultCount) = resultAreainfo = "操作成功!" & vbCrLf & "共查询到" & resultCount & "条车牌号为[" & carID & "]的用户信息!"MsgBox info, vbInformation, "查询结果"txtTargetCarID.Text = ""txtTargetCarID.SetFocusApplication.ScreenUpdating = TrueEnd SubPrivate Sub cmdCancel_Click()fmQuery.HideSheet2.Activate
End Sub

运行结果:

(1)录入重复车牌号时:




(2)录入不重复车牌时:





(3)查询到已有车牌时:(多条记录)





(4)未查询到结果时:




要点小结

1、命名统一采用“控件简称+描述性名称”(如txtDate、cmdSave等)的方式,便于后期维护与更新;

2、选中文本框中文本的方法:

        txtUserCarNo.SetFocustxtUserCarNo.SelStart = 0txtUserCarNo.SelLength = Len(carID)

3、获取工作表中整列区域:

Sheet1.Columns("B:B").Cells
4、获取当前区域的最后一行行标:

Sheet1.Range("A65536").End(xlUp).Row

5、格式化当前时间:

Format(Date, "yyyy/m/d")

6、初始化窗体的控件事件不能使用自定义名称:

正确:

Private Sub UserForm_Initialize()...
End Sub

错误:

Private Sub fmInput_Initialize()...
End Sub

7、命令按钮快捷键设置:用Accelerator属性

指定按钮快捷键

8、使用动态数组节约内存资源:

        Dim resultArea()ReDim resultArea(1 To resultCount, 1 To 5)

这篇关于用Excel VBA代码实现去重录入某字段内容的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/289139

相关文章

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll

Spring Security自定义身份认证的实现方法

《SpringSecurity自定义身份认证的实现方法》:本文主要介绍SpringSecurity自定义身份认证的实现方法,下面对SpringSecurity的这三种自定义身份认证进行详细讲解,... 目录1.内存身份认证(1)创建配置类(2)验证内存身份认证2.JDBC身份认证(1)数据准备 (2)配置依

利用python实现对excel文件进行加密

《利用python实现对excel文件进行加密》由于文件内容的私密性,需要对Excel文件进行加密,保护文件以免给第三方看到,本文将以Python语言为例,和大家讲讲如何对Excel文件进行加密,感兴... 目录前言方法一:使用pywin32库(仅限Windows)方法二:使用msoffcrypto-too

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式