Format方法使用详解
作者:pS看云梦山水Tn | 来源:互联网 | 2023-05-19 01:38
VBA的Format函数与工作表函数TEXT用法基本相同,但功能更加强大,许多格式只能用于VBA的Format函数,而不能用于工作表函数TEXT,以下是本人归纳的几点
VBA 的 Format 函数与工作表函数 TEXT 用法基本相同,但功能更加强大,许多格式只能用于VBA 的 Format 函数,而不能用于工作表函数 TEXT ,以下是本人归纳的几点用法,不到之处,敬请谅解。
Format(值,格式(可选参数))
一、数字格式:
1、General Number:普通数字,可以用来去掉千位分隔号和无效 0 。
如:Format("1,234,567.80", "General Number")="1234567.8"
2、Currency:货币类型,可添加千位分隔号和货币符号,保留两位小数点。
如:Format(1234567, "Currency")="¥1,234,567.00"
3、Fixed:格式为带两位小数的数字。
如:Format("123456", "Fixed")=123456.00
4、Standard:标准,即带千位分隔号和两位小数。
如:Format("123456", "Standard")=123,456.00
5、Percent:带两位小数点的百分数。
如:Format("123456", "Percent")=12345600.00
6、Scientific:科学记数法。
如:Format("1234567", "Scientific")=1.23E+06
7、Yes/No:当数值为非 0 数字时返回 Yes ,否则返回 No 。
"如:Format(-3.14, "Yes/No")="Yes"
Format(0, "Yes/No")="No"
8、True/False:当数值为非 0 数字时返回 True ,否则返回 False 。
与第7点类似,这里不再举例。
9、On/Off:当数值为非 0 数字时返回 On ,否则返回 Off 。
与第7点类似,这里不再举例。
10、""或省略:返回原值,但去除了小数点前后的无效 0 。
如:Format("0.1030", "")=".103"
11、0:占位格式化,不足位时补足 0 。
"如:Format(123, "0000")="0123"
Format$(12.3, "0.00")="12.30"
12、#:占位格式化,不足位时不补足 0 。
如:Format(123, "####")=123
13、%:转化为百分数,一个%代表乘以 100 。
如:Format(1.23, "0.00%")=123.00%
Format(1.23, "0.00%%")=12300.00%%
14、\:强制显示某字符。
如:Format$(12.34, "\R\M\B .00")="RMB 12.34"
15、;(分号):分段显示不同格式
比如要把正数显示为“正”,负数显示为“负”,0显示为“零”,参数为"正;负;零"
如:Format$(123, "正;负;零")="正"
第1段为正数格式,第2段为负数格式,第3段为0格式。
二、日期和时间格式:
1、固定格式参数
General Date:基本类型
如:Format("2010-5-1 9:8:5", "General Date")="2010/5/1 9:08:05"
Long Date:操作系统定义的长日期
如:Format("2010-5-1 9:8:5", "Long Date")=2010年5月1日
Medium Date:中日期
如:Format("2010-5-1 9:8:5", "Medium Date")=10-05-01
Short Date:操作系统定义的短日期
如:Format("2010-5-1 9:8:5", "Short Date")=2010-5-1
Long Time:操作系统定义的长时间
如:Format("2010-5-1 9:8:5", "Long Time")=9:08:05
Medium Time:带AM/PM(上午/下午)的12小时制,不带秒
如:Format("2010-5-1 9:8:5", "Medium Time")=09:08 上午
Short Time:24时制的时间,不带秒
如:Format("2010-5-1 9:8:5", "Short Time")=09:08
2、自定义格式
C:格式化为国标的日期和时间
如:Format("2010-5-1 9:8:5", "c")=2010/5/1 9:08:05
y:一年中的第几天(1-366)
如:Format("2010-5-1 9:8:5", "y")=121
yy:两位数的年份(00-99)
如:Format("2010-5-1 9:8:5", "yy")=10
yyy:上面的 yy 与 y 结合在一起
"如:Format("2010-5-1 9:8:5", "yyy")=10121
Format("2010-5-1 9:8:5", "yy年第y天")=10年第121天
yyyy:四位数的年份(0100-9999)
如:Format("2010-5-1 9:8:5", "yyyy")=2010
d:一个月中的第几天(1-31)
如:Format("2010-5-1 9:8:5", "d")=1
dd:与 d 相同,但不足两位时补足 0
如:Format("2010-5-1 9:8:5", "dd")=01
ddd:三个英文字母表示的星期几
如:Format("2010-5-1 9:8:5", "ddd")="Sat"
dddd:英文表示的星期几
如:Format("2010-5-1 9:8:5", "dddd")="Saturday"
ddddd:显示标准日期
如:Format("2010-5-1 9:8:5", "ddddd")=2010/5/1
dddddd:长日期
如:Format("2010-5-1 9:8:5", "dddddd")=2010年5月1日
w:一个星期中的第几天(始于周日,周日为1)
如:Format("2010-5-1 9:8:5", "w")=7
ww:一年中的第几周
如:Format("2010-5-1 9:8:5", "ww")=18
m:月份数(当用于时间时,也可以表时为分钟)
如:Format("2010-5-1 9:8:5", "m")=5
mm:当小于10时带前导0的月数(当用于时间时,也可以表示为两位数的分钟数)
如:Format("2010-5-1 9:8:5", "mm")=05
mmm:三个英文字母表示的月份数
如:Format("2010-1-1 9:8:5", "mmm")="Jan"
mmmm:英文表示的月份数
如:Format("2010-1-1 9:8:5", "mmmm")="January"
q:一年中的第几季(1-4)
如:Format("2010-5-1 9:8:5", "q")=2
aaa:中文表示的周几
如:Format("2010-5-1 9:8:5", "aaa")=周六
aaaa:中文表示的星期几
如:Format("2010-5-1 9:8:5", "aaaa")=星期六
h:小时数(0-23)
如:Format("2010-5-1 9:8:5", "h")=9
h:两位数表示的小时数
如:Format("2010-5-1 9:8:5", "hh")=09
n:分钟数(0-59)
如:Format("2010-5-1 9:8:5", "n")=8
nn:两位数表示的分钟数(00-59)
如:Format("2010-5-1 9:8:5", "nn")=08
s:秒数(0-59)
如:Format("2010-5-1 9:8:5", "s")=5
ss:两位数表示的秒数(00-59)
如:Format("2010-5-1 9:8:5", "ss")=05
ttttt:标准时间,当小时数小于10时不带0,与 h:mm:ss 或 h:nn:ss 相同
如:Format("2010-5-1 9:8:5", "ttttt")=9:08:05
AM/PM:显示当前为AM或PM
如:Format("2010-5-1 11:59:59", "AM/PM")=AM
Format("2010-5-1 12:0:0", "AM/PM")=PM
A/P:显示当前为A或P
与 AM/PM 一样,这里不再举例。
说明:
可以多种格式联合使用,如:
Format("2010-5-1 9:8:5", "dddddd aaaa")=2010年5月1日 星期六
三、文本格式
@:匹配位置插入格式化文本,如:
在"abcde"前插入文本"X",代码为:Format("abcde", "[email=X@]X@")=Xabcde[/email]
在"abcde"第1位字符后面插入文本"X",代码为:Format("abcde", "@X")=aXbcde
在"abcde"第2位字符后面插入文本"X",代码为:Format("abcde", "@@X")=abXcde
在"abcde"第3位字符后面插入文本"X",代码为:Format("abcde", "@@@X")=abcXde
当点位符@比原文本字符串多时,刚在相应位置上添加空格,如:
Format("abc", "[email=X@@@@]X@@@@")="X[/email] abc"
Format("abc", "[email=X@@@@@]X@@@@@")="X[/email] abc"
Format("t", "@@a@")=" at"(空格空格at)
与!配合可从后面截取一段文本,如:
截取"abcde"后面1个字符文本,代码为:Format("abcde", "[email=!@]!@")=e[/email]
截取"abcde"后面2个字符文本,代码为:Format("abcde", "[email=!@@]!@@")=de[/email]
截取"abcde"后面3个字符文本,代码为:Format("abcde", "[email=!@@@]!@@@")=cde[/email]
截取"abcde"后面两位,并在前面添加"XY",代码为:Format("abcde", "[email=!XY@@]!XY@@")=Xyde[/email]
&:字符占位符,与@基本相同,这里不再赘述。
<:强制将所有字符以小写格式显示。
如:Format$("I Love You", "<")=i love you
>:强制将所有字符以大写格式显示。
如:Format$("I Love You", ">")=I LOVE YOU
推荐阅读
-
IamtryingtocomparecellvaluesinaloopwithVBA.TheloopthatIwasusingwasthis我正在尝试将循环中 ...
[详细]
蜡笔小新 2023-09-13 11:58:03
-
因此,我设法获取了此宏以创建新的工作表,从单元格值命名工作表,并将一些 ...
[详细]
蜡笔小新 2023-09-24 15:31:49
-
-
Codebelowwascreated(notbyme,andsavedas*.dotm)inMicrosoftWord97-2003,whendefaultins ...
[详细]
蜡笔小新 2023-09-25 12:30:39
-
Tryingtosaveanew,notyetnamed,workbook(thatIaddedusinganothersub)withvariablesforth ...
[详细]
蜡笔小新 2023-09-16 01:33:25
-
ImusingCDatetoconvertaparticulardateformattedasstringtotheExcelDatetype.Iwroteas ...
[详细]
蜡笔小新 2023-09-15 17:55:38
-
IamactuallyworkingonmyfirstVBAproject.(comefromC++)我正在做我的第一个VBA项目。(来自C++)Iwouldlik ...
[详细]
蜡笔小新 2023-09-08 19:39:29
-
本文由编程笔记#小编为大家整理,主要介绍了logistic回归(线性和非线性)相关的知识,包括线性logistic回归的代码和数据集的分布情况。希望对你有一定的参考价值。 ...
[详细]
蜡笔小新 2023-12-14 21:40:43
-
本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ...
[详细]
蜡笔小新 2023-12-14 16:06:38
-
本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ...
[详细]
蜡笔小新 2023-12-13 15:15:30
-
本文详细介绍了在IOS开发中实现短信发送和拨打电话的两种方式,一种是使用系统底层发送,虽然无法自定义短信内容和返回原应用,但是简单方便;另一种是使用第三方框架发送,需要导入MessageUI头文件,并遵守MFMessageComposeViewControllerDelegate协议,可以实现自定义短信内容和返回原应用的功能。 ...
[详细]
蜡笔小新 2023-12-11 20:15:47
-
本文介绍了在MFC下利用C++和MFC的特性动态创建窗口的方法,包括继承现有的MFC类并加以改造、插入工具栏和状态栏对象的声明等。同时还提到了窗口销毁的处理方法。本文详细介绍了实现方法并给出了相关注意事项。 ...
[详细]
蜡笔小新 2023-12-11 15:09:27
-
本文介绍了如何将公司内部的Gitlab系统接入单点登录服务,并提供了安装和配置的详细教程。通过使用oauth2协议,将原有的各子系统的独立登录统一迁移至单点登录。文章包括Gitlab的安装环境、版本号、编辑配置文件的步骤,并解决了在迁移过程中可能遇到的问题。 ...
[详细]
蜡笔小新 2023-12-10 14:38:53
-
VBA操作Excel简介一、VBA读写Excel文件二、VBA设置单元格属性三、VBA弹出输入和输出窗口参考文档一、VBA读写Excel文件VBA简介及打开Excel文件方法见VB ...
[详细]
蜡笔小新 2023-10-17 16:48:53
-
IhavedatainmultipleDataworksheetsthatwanttocombineintoSummaryworksheet.Whenuserupdat ...
[详细]
蜡笔小新 2023-10-10 14:26:43
-
Subex2()Sheets(sheet2).Range(a2).TextAnilEndSubIwanttocopythedataAnilinto ...
[详细]
蜡笔小新 2023-10-10 11:25:04
-