VBA如何快速识别Excel单元格中的文本数字

news/2024/10/31 1:29:57/

Excel中一种非常特殊的数字,这些数字看似数字,其实是文本格式(下文简称为文本数字),在单元格的左上角会有一个绿色小三角作为标志,如B1:B3单元格。
在这里插入图片描述

在编程时为什么需要区分普通数字和文本数字呢?先来看以下【立即窗口】种的测试代码。A1和B1单元格内容看似相同,但是测试代码的结果却完全不同。

  • 单元格A1为普通数字,加号之后的"0"被转换为数字零,然后进行加法运算。
  • 单元格B1为文本数字,加号作为字符串连接运算符,合并两个字符串。
?[A1]+"0"1 
?[B1]+"0"
10

VBA代码并无法识别单元格坐上角的绿色三角标志,或者说Range对象并没有一个属性值对应这个标志,但是可用通过自定义函数来区分这两种数字格式。

Function IsNumberStoredAsText(Rng As Range) As VariantIf Not IsNumeric(Rng) ThenIsNumberStoredAsText = vbNullCharExit FunctionEnd IfIf Rng.Value + "0" = Rng.Value ThenIsNumberStoredAsText = vbNoElseIsNumberStoredAsText = vbYesEnd If
End Function

【代码解析】
第2行代码判断单元格内容是否为数字,如果不是数字则第3行代码返回vbNullChar
第6行代码利用+ "0"运算来判别单元格中数字格式,如果运算结果与单元格的值相等,第7行代码返回vbNo,即单元格内容为普通数字,如果不等,第9行代码返回vbYes,即单元格内容为文本数字。


测试代码如下。

Sub DEMO()Dim c As Range, sMsg As StringFor Each c In Range("A1:B4").CellsSelect Case IsNumberStoredAsText(c)Case Is = vbNullCharsMsg = "非数字"Case Is = vbYessMsg = "文本数字"Case Is = vbNosMsg = "普通数字"End SelectDebug.Print "单元格[" & c.Address & "]:" & sMsgNext
End Sub

【代码解析】
第3~13行代码循环遍历单元格。
第4~11行代根据自定义函数返回值提供不同的内容。
第12行代码在【立即窗口】中输入结果,如下所示。

单元格[$A$1]:普通数字
单元格[$B$1]:文本数字
单元格[$A$2]:普通数字
单元格[$B$2]:文本数字
单元格[$A$3]:普通数字
单元格[$B$3]:文本数字
单元格[$A$4]:非数字
单元格[$B$4]:非数字

http://www.ppmy.cn/news/1228968.html

相关文章

代码随想录算法训练营第五十九天 | LeetCode 739. 每日温度、496. 下一个更大元素 I

代码随想录算法训练营第五十九天 | LeetCode 503. 下一个更大元素 II、42. 接雨水 文章链接:下一个更大元素 II、接雨水 视频链接:下一个更大元素 II、接雨水 1. LeetCode 503. 下一个更大元素 II 1.1 思路 本题是给一个数组求右边第一个比当前元素大的…

如何搞定电子画册制作,分分钟在线制作与宣传!

一提到公司宣传,大多数人会想到的是制作视频或纸质的小册子。随着互联网技术的发展,如今可以用电子画册来做宣传,不仅可以跨空间地域传播,并且仅需图文排版设计好,通过在线电子画册制作工具转换就能简单实现宣传&#…

ARTS 打卡第一周

ARTS AlgorithmReviewTipShare Algorithm 题目 class Solution {func mergeAlternately(_ word1: String, _ word2: String) -> String {var ans ""var idx1 word1.startIndexvar inx2 word2.startIndexwhile idx1 < word1.endIndex || idx2 < word2.e…

Java shp 转 GeoJson

文章目录 1. 依赖安装1.1 配置软件源1.2 引入依赖 2. 功能实现3. 参考链接 1. 依赖安装 1.1 配置软件源 在项目 pom.xml 添加, maven 的 settings.xml 配置的源&#xff0c;mirrorOf 不能是 *,不然安装不上 <project>...<repositories><repository><id…

第二部分:Module(也称为Package)

Module是一个传统的&#xff0c;较成熟的设计元数&#xff0c;虽然使用模块有一些技术上的原因&#xff0c;但主要原因确是“认知超载”。它为我们提供了两种观察模式&#xff0c;一是可以在module中查看细节&#xff0c;而不会被整个模型淹没&#xff0c;二是观察module之间的…

[Kettle] 公式

公式是用来计算数据流中数据的表达式 公式可以是"AB"这样的简单计算&#xff0c;也可以是类似"if/then"复杂业务逻辑判断的表达式 数据源 2019年11月月考成绩(Kettle数据集16).xlshttps://download.csdn.net/download/Hudas/88553816?spm1001.2014.300…

大白话解释什么类加载机制

大家好&#xff0c;我是伍六七。 今天我们来聊聊一个 Java 面试必考基础题目&#xff1a;类加载机制和双亲委派机制。 Java 类的加载机制是 Java 虚拟机&#xff08;JVM&#xff09;中类加载&#xff08;Class Loading&#xff09;和链接&#xff08;Linking&#xff09;的过…

pytest测试框架介绍(1)

又来每天进步一点点啦~~~ 一、Pytest介绍&#xff1a; pytest 是一个非常成熟的全功能的Python测试框架&#xff1b; pytest 简单、灵活、易上手&#xff1b; 支持参数化 能够支持简单的单元测试和复杂的功能测试&#xff0c;可以做接口自动化测试&#xff08;pytestrequests&…