VBA的Format函数

Format(值,格式(可选参数))
一、数字格式:
1、General Number:普通数字,可以用来去掉千位分隔号和无效 0。
如:Format("1,234,567.80", "GeneralNumber")="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、固定格式参数
GeneralDate:基本类型
如:Format("2010-5-1 9:8:5", "GeneralDate")="2010/5/1 9:08:05"
LongDate:操作系统定义的长日期
如:Format("2010-5-1 9:8:5", "LongDate")=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
MediumTime:带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-19: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-19:8:5", "ddddd")=2010/5/1
dddddd:长日期
如:Format("2010-5-19:8:5", "dddddd")=2010年5月1日
w:一个星期中的第几天(始于周日,周日为1)
如:Format("2010-5-1 9:8:5", "w")=7
ww:一年中的第几周
如:Format("2010-5-19:8:5", "ww")=18
m:月份数(当用于时间时,也可以表时为分钟)
如:Format("2010-5-19: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-19:8:5", "h")=9
h:两位数表示的小时数
如:Format("2010-5-1 9:8:5", "hh")=09
n:分钟数(0-59)
如:Format("2010-5-19: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", "X@")=Xabcde
在"abcde"第1位字符后面插入文本"X",代码为:Format("abcde", "@X")=aXbcde
在"abcde"第2位字符后面插入文本"X",代码为:Format("abcde", "@@X")=abXcde
在"abcde"第3位字符后面插入文本"X",代码为:Format("abcde", "@@@X")=abcXde
当点位符@比原文本字符串多时,刚在相应位置上添加空格,如:
Format("abc", "X@@@@")="X abc"
Format("abc", "X@@@@@")="X  abc"
Format("t", "@@a@")="  at"(空格空格at)
与!配合可从后面截取一段文本,如:
截取"abcde"后面1个字符文本,代码为:Format("abcde", "!@")=e

截取"abcde"后面2个字符文本,代码为:Format("abcde","!@@")=de
截取"abcde"后面3个字符文本,代码为:Format("abcde", "!@@@")=cde

截取"abcde"后面两位,并在前面添加"XY",代码为:Format("abcde","!XY@@")=XYde

&:字符占位符,与@基本相同

<:强制将所有字符以小写格式显示。
如:Format$("I Love You", "<")=i love you
>:强制将所有字符以大写格式显示。
如:Format$("ILove You", ">")=I LOVE YOU

(0)

相关推荐

  • Text函数的6大奇妙用法

    关键词:商品编码0开头.格式日期转化.返回星期几.百分比显示.条件区段返回.自定义条件区段 效果图预览: 解析函数: TEXT(value,format_text) 1.  其中value 为数值.计 ...

  • Python字符串及其简单格式化

    Python字符串及其简单格式化

  • 又到了撸串的好时节

    我,老崔 前言 说起撸串,大家都知道,不管是什么串都是一个个用钎子串起来的.其实工作中我们也经常要把几个字符串和或单元格连接起来,同样也是需要一根钎子,今天就讲讲字符串的连接方法. 1A&B& ...

  • VS2019 v16.10中头文件更新了

    C++ 20向标准库中添加了一个新型的文本格式化基础设施,主要用来替换传统的snprintf之类的函数,随之带来的是:更快的执行速度和更加安全的接口.C++标准库中的实现是基于现有的{fmt}开源库, ...

  • excel VBA的Format函数使用基础教程

    Format(值,格式(可选参数)) 一.数字格式: 1.General Number:普通数字,可以用来去掉千位分隔号和无效 0 . 如:Format("1,234,567.80" ...

  • Exce复杂数据提取 VBA正则表达式结合函数

    Exce复杂数据提取 VBA正则表达式结合函数

  • VBA中OFFSET函数的实际利用

    今日继续讲VBA实用代码的第十讲,相信大家通过这系列的文章学到了很多,今日着重讲解OFFSET函数在VBA中的利用. 1 Range("A32", Range("A32& ...

  • Excel VBA 7.37单工作薄跨工作表按类对指定列进行求和,vba VS sum函数!

    一起学习,一起进步~~ 昨天我们分享了关于数据计算的第一篇,主要针对相同数据类进行求和,这种求和方法能够实现sum()函数无法实现的方法,我不是函数高手,理论上来说可能需要的公式也比较的长,今天我们继 ...

  • 利用FORMAT函数自定义数据格式

    在进行数据分析时,需要对某个数据进行格式调整的情形经常会遇到,在DAX中有一个专门进行格式调整的函数:FORMAT. 其实对于 FORMAT 函数并不陌生,在之前介绍如何制作日期表时,其中一种方式就是 ...

  • VBA中ROUND函数浅析

    VBA四舍五入函数round()的一些不同四舍五入对于我们来说再熟悉不过了,但这次却碰到一个麻烦的问题. 由于实行全员个人所得税申报,从地税拿到了个人所得税申报软件,按要求把数据都导入后,软件计算出所 ...

  • delphi中的Format函数详解

    Format是一个很常用,却又似乎很烦的方法,本人试图对这个方法的帮助进行一些翻译 ,让它有一个完整的概貌,以供大家查询之用: 首先看它的声明: function Format(const Forma ...

  • 持续时间无法显示?FORMAT函数学好了【含免费视频】!| PBI函数应用

    在PQ里,有一种字段类型叫"持续时间": 这种数据,其实是两个时间点的差值,比如,我们可以直接用两个时间相减,得到持续时间: 同时,可以看到,"持续时间"的格式 ...

  • 如何用VBA代替VLOOKUP函数?

    广告 Excel VBA经典代码应用大全 作者:Excel Home 当当 一盏离愁 孤单伫立在窗口 我在门后 假装你人还没走 东风破 周杰伦 - 叶惠美 哈罗,大家好,我是星光,今天和大家分享的主题 ...