当先锋百科网

首页 1 2 3 4 5 6 7

 

 

在使用VBScript常需要使用格式化出日期的方法,总结也一下,如下:

 


1.使用FormatDateTime函数

此函数返回表达式,此表达式已被格式化为日期或时间。

FormatDateTime 函数使用格式为FormatDateTime(Date[, NamedFormat])

其中

Date必选项。要被格式化的日期表达式。

NamedFormat可选项。指示所使用的日期/时间格式的数值,如果省略,则使用 vbGeneralDate

NamedFormat 参数能有以下值:

常数

描述

vbGeneralDate

0

示日期和/时间。如果有日期部分,部分短日期格式。如果有时间部分,部分为长时间格式。如果都存在,则显示所有部分。

vbLongDate

1

使用算机区域置中指定的日期格式示日期。

vbShortDate

2

使用算机区域置中指定的短日期格式示日期。

vbLongTime

3

使用算机区域置中指定的时间格式时间

vbShortTime

4

使用 24 格式 (hh:mm) 时间

 

 

2.自定义输出,如将201099日输出为20100909

VBScript自带的日期格式功能不支持两位数日期的格式,如果使用如下代码

strDate= CStr(Year(Now()))&Cstr(Month(Now()))&Cstr(Day(Now()))

strDate中的字符为201099

解决此问题的方法有如下几种:

1)写一个处理函数,比如叫做Get2Digits

if len(month(now))=1 then month="0"&month

这样每次都调用这个函数即可。

2)我们也可以通过这种方式获取:right("0"&Month(now),2),这个函数的作用实际上很简单,先给月份前面强制加字符“0”,这样格式就变成了0608012,然后取右边的两个字符,也就是060812。这样既简短又避免了过多的if判断语句导致程序执行变慢的问题。这种方法显然要好很多。则刚才的可以改为

strDate=CStr(Year(Now()))&Right("0"&Month(Now()),2)&Right("0"&Day(Now()),2)

3Now()输出的格式为2010/09/09 12:47:59

所以我们也可以采取这种方式格式化输出日期

strDate=Left(Now(),4)&Mid(Now(),6,2)&Mid(Now(),9,2)

但是,有一点注意,我测试了一下,这种方式在日文OS下是可以使用的,因为此时Now()的结果是2010/09/09 12:47:59这种格式的,但是在英文OSNow()的结果是09/09/2010 12:47:59,此时就要对上面的方法进行更改,这个要十分注意!