通过VBA,当在EXCEL单元格中输入任意的日期格式时,都能自动转换为指定的标准格式的日期值
在日常录入EXCEL表格的单元格里 ,我们输入一些一般性的日期内容,如:2017-10-17 或 2017/10/17时,EXCEL会自动识别为日期并按单元格设计格式显示,单元格中存储的值也是日期格式的值。
但我们进行不规范的日期输入时,如在单元格中输入:2017.10.10或2017。10。10或20171010时,EXCEL不会自动识别这些内容为日期,而只会识别为字符串(文本),且在单元格中存储的也只是文本而已。
我们通过编写VBA代码可以轻松解决此问题,让EXCEL完美识别输入的任何日期内容,不管是20171010或2017.10.10还是201711或20170101或2017131都可被正确识别,而且是直接将单元格中存储的值转换为日期值,不仅仅是显示格式的转换。
闲话不说,直接让VBA代码:
(要录入VBA代码,必须通过EXCEL进入VBA编辑器,这部分内容可搜索下)
'以下代码都要放到一个sheet的类模块之中
Dim nDate
Private Sub Worksheet_Activate()'加载sheet的事件
nDate = InputBox("请确定此工作表中第几列为日期型的数据!", "输入数字", "")
If nDate = "" Then
nDate = 2 '--只操作指定的列号的列,目前只操作B列(第2列)
Else
nDate = Val(nDate)
End If
End Sub
Private Sub Worksheet_Change(ByVal Target As Range)'--sheet中任何地方发生数据改变时触发的事件
If nDate = Then Exit Sub
If Target.Cells.Column = nDate Then '--如果是第二列才检验文本为日期
Target.Value = TryChangeDate2(Target.Value)
End If
End Sub
Public Function TryChangeDate2(ByVal strDATEcome As String) As Variant
On Error GoTo TryChangeDate2ERR
Dim strDATE As String
strDATE = Trim(strDATEcome)
Dim myDate As Date
Dim strK As String
strK = mTrim(strDATEcome)
Dim k As Integer, nkkkk As Integer
k = -
k0:
k =
myDate = DateValue(strDATE)
myDate = Format(myDate, "yyyy/m/d")
TryChangeDate2 = myDate
Exit Function
k1:
k =
myDate = DateValue(strDATE)
myDate = Format(myDate, "yyyy/m/d")
TryChangeDate2 = myDate
Exit Function
TryChangeDate2ERR:
Err.Clear
If k = Then
nkkkk = Len(strK)
Select Case nkkkk
Case
If InStr(, strK, ".") = And InStr(, strK, ",") = And InStr(, strK, "/") = And InStr(, strK, "\") = And InStr(, strK, "-") = Then
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
End If
Case
If InStr(, strK, ".") = And InStr(, strK, ",") = And InStr(, strK, "/") = And InStr(, strK, "\") = And InStr(, strK, "-") = Then
If Val(Mid(strK, , )) >= Then
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
Else
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
End If
End If
Case
If InStr(, strK, ".") = And InStr(, strK, ",") = And InStr(, strK, "/") = And InStr(, strK, "\") = And InStr(, strK, "-") = Then
If Left(strK, ) = "" Or Left(strK, ) = "" Then
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
Else
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
End If
GoTo theEnd
End If
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
Case
If InStr(, strK, ".") = And InStr(, strK, ",") = And InStr(, strK, "/") = And InStr(, strK, "\") = And InStr(, strK, "-") = Then
If Val(Mid(strK, , )) >= Then
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
Else
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
End If
Else
If Val(Mid(strK, , )) >= Then
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
Else
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
End If
End If
Case
If InStr(, strK, ".") = And InStr(, strK, ",") = And InStr(, strK, "/") = And InStr(, strK, "\") = And InStr(, strK, "-") = Then
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
Else
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
End If
Case
If Val(Mid(strK, , )) >= Then
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
Else
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
End If
Case
strDATE = Left(strK, ) & "/" & Mid(strK, , ) & "/" & Mid(strK, , )
End Select
theEnd:
GoTo k1
End If
TryChangeDate2 = strDATEcome
End Function Public Function mTrim(ByVal strCome As String) As String
'--此函数的作用是去掉字符串中间的空格
On Error GoTo mTrimErr
Dim i As Integer, j As Integer
Dim strLS As String, k As String * , strResult As String
strLS = Trim(strCome)
strResult = ""
j = Len(strLS)
For i = To j
k = Mid(strLS, i, )
If k <> " " And k <> " " And VarType(k) <> vbNull And k <> vbNullString Then
strResult = strResult & k
End If
Next
mTrim = strResult
Exit Function
mTrimErr:
Err.Clear
mTrim = strCome
End Function '---以上代码可实现在EXCEL指定列(上面指定为B列)中录入日期内容时,任意可识别的日期都会被自动转换成标准日期值,并以日期值存储在单元格中
'---欢迎大家批评指正,如果发现错误,欢迎指正,如有不明子的地方,欢迎交流
'--QQ: 578652607
通过VBA,当在EXCEL单元格中输入任意的日期格式时,都能自动转换为指定的标准格式的日期值的更多相关文章
- 在一个Excel单元格内输入多行内容
有时候,我们想在一个Excel单元格中输入多行内容,可以根据不同情况选择下面的方法来实现: 方法一:如果有大量的单元格需要这样做,采取此种设置格式的方法,选中需要这种格式的单元格,执行“格式→单元格” ...
- 如何在excel单元格中插入图片批注
在excel单元格中插入图片批注的方法: 1.选定要插入图片的单元格,然后右键选择插入批注. 2.然后会插入一个批注框,为了不影响图片效果,可以将批注文字都删除.然后鼠标移动到批注框边角再右键. 3. ...
- excel单元格中批量加入固定字符
excel单元格前怎么批量加字母 现在我要在联系人这列,每个姓名前加入衡阳的首字母简写(HY). 3 在同行上面随便找列,我找D列.输入公式:="HY"&A2. 5 输入后 ...
- POI如何自动调整Excel单元格中字体的大小
问题 目的是要将Excel中的文字全部显示出来,可以设置对齐格式为[缩小字体填充],但是这样的话只能展示出一行数据,字体会变得很小.还有一种办法,设置对齐格式为[自动换行],然后让单元格中的字体自动调 ...
- Java 在Excel单元格中应用一种/多种字体样式
在Excel表格中,设置单元格字体样式时,可以对单元格内的所有字符应用同一样式,即获取指定单元,应用样式即可:另外也可以对单元格内的不同字符内容应用不同字体样式,即获取单元格中的字符位置,应用样式:本 ...
- C#/VB.NET 在Excel单元格中应用多种字体格式
在Excel中,可对单元格中的字符串设置多种不同样式,通常只需要获取到单元格直接设置样式即可,该方法设置的样式会应用于该单元格中的所有字符.如果需要对单元格中某些字符设置样式,则可以参考本文中的方法. ...
- 在excel单元格中提取信息
平时在excel中处理数据的时候,肯定会遇到在单元格提取信息的情况,比如在地址中提取省.市.地区等,如果数据源内容规整的话,可以直接使用left().right().mid()等函数直接提取,但是大多 ...
- 实现Excel单元格中的下拉选项
目的:控制数据录入的类型和具体数据的限制,避免数据错误输入 操作步骤: 1.选中需要设置下拉菜单的单元格 2.单击数据选项卡---数据有效性---设置选项卡---允许功能中选择序列---在来源编辑框中 ...
- python实现处理excel单元格中的数据
实现代码如下: # 将数据单元格(格式为:参数名=值)里的数据以键值对的形式放入字典中,返回该字典 class get_string: def cut_string(self,string): # 将 ...
随机推荐
- 5th-个人总结(Alpha阶段)
一. 总结自己的Alpha过程 1.团队的整体情况 在团队中这次担任队长的职务. alpha阶段完成情况还算理想,大家都完成了指定的任务.但是也少不了犯错,一些需求没有划分的足够细致,后来功能完成后发 ...
- C++学习笔记——STL(标准模板库)
1.首先.需要学习C++ 模板的概念 2.C++ STL(标准模板库)是一套功能强大的 C++ 模板类,提供了通用的模板类和函数,这些模板类和函数可以实现多种流行和常用的算法和数据结构,如向量.链表. ...
- 201521123025《java程序设计》第七周学习总结
1. 本周学习总结 2. 书面作业 Q1.ArrayList代码分析 1.1 解释ArrayList的contains源代码 public boolean contains(Object o) { r ...
- 201521123050 《Java程序设计》第7周学习总结
1. 本周学习总结 2. 书面作业 1.ArrayList代码分析 1.1 解释ArrayList的contains源代码 代码: public boolean contains(Object o) ...
- 201521123037 《Java程序设计》第9周学习总结
1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常相关内容. java异常继承架构 2. 书面作业 本次PTA作业题集异常 1. 常用异常 题目5-1 1.1 截图你的提交结果( ...
- 201521123002《Java程序设计》第14周学习总结
本次作业参考文件 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多数据库相关内容. MySql数据库简单操作: 库操作: 显示所有数据库: show databases; 创建数 ...
- 201521123019 《java程序设计》 第13周学习总结
1. 本章学习总结 2. 书面作业 Q1. 网络基础 1.1 比较ping www.baidu.com与ping cec.jmu.edu.cn,分析返回结果有何不同?为什么会有这样的不同? 访问cec ...
- Java 最常用类(前1000名) 来自GitHub 3000个项目
这篇文章主要介绍了最常用的1000个Java类(附代码示例),需要的朋友可以参考下 分析Github 3000个开源项目,粗略统计如下.括号内的数字是使用频率 0-3000. 下面的列表显示不全,完整 ...
- Mysql常用命令大全
1.连接Mysql 格式: mysql h主机地址 u用户名 -p用户密码 2.1 创建数据库 命令:create database <数据库名> 例1:建立一个名为xhkdb的数据库 ...
- oracle 建表空间->创建用户并把表空间分配给用户->给用户授权->导库
首先注意:我参考网上使用的sysdba模式(normal)登陆的,其他的模式建不了用户(个人没有进行其他模式的表空间尝试,如有人尝试欢迎补充,感激不尽) 表空间相当于表的容器(一下所有的操作都适用于o ...