为什么要将日期型数据转换为长整型数据呢?原因很多,但就我个人来说,经常将它用于数据库的日期存储。由于各种数据库对日期型的定义和处理是不一样的,各种语言对日期型数据的定义的处理也各不相同,因为,我宁愿将日期型数据转换成长整型再保存到数据库中。虽然也可以使用字符串来保存,但使用字符串也会涉及到许多问题,如区域等问题,而且,它需要比保存长整型数据更多的空间。
日期型数据,在 C# 中的参与运算的时候,应该也是转换为长整型数据来运算的。它的长整型值是自 0001 年 1 月 1 日午夜 12:00 以来所经过时间以 100 毫微秒为间隔表示时的数字。这个数在 C# 的 DateTime 中被称为 Ticks(刻度)。DateTime 类型有一个名为 Ticks 的长整型只读属性,就保存着这个值。如此,要从一个 DataTime 型数据得到 long 型值就非常简单了,只需要读出 DataTime 对象的 Ticks 值即可,如:
long longDate = DateTime.Now.Ticks;
DateTime 的构造函数中也提供了相应的,从长整型数据构造 DateTime 型数据的函数:DateTime(long)。如:
DateTime theDate = new DateTime(longDate);
但这样对于很多 VB6 程序员来说,是给他们出了一道难题,因为 VB6 中的日期型数据内部是以 Double 型表示的,将其转换为长整型后得到的仅仅是日期,而没有时间。如何协调这两种日期类型呢?
System.DateTime 提供了 double ToOADate() 和 static DateTime FromOADate(double) 两个函数来解决这个问题。前者将当前对象按原来的 double 值输出,后者则从一个 double 值获得一个 System.DateTime 对象。举例如下:
TestDateTimeLong() { doubleDate = DateTime.Now.ToOADate(); DateTime theDate = DateTime.FromOADate(doubleDate); .textBox1.Text = ; .textBox1.AppendText( + doubleDate.ToString() + ); .textBox1.AppendText( + theDate.ToString() + ); }
运行结果:
Double value of now: 37494.661541713
DateTime from double value: 2002-8-26 15:52:37
10. 格式化日期型数据
编程的过程中,通常需要将日期型数据按照一定的格式输出,当然,输出结果肯定是字符串。为此,我们需要使用 System.DateTime 类的 ToString() 方法,并为其指定格式字符串。MSDN 中,System.Globalization.DateTimeFormatInfo 类的概述里对模式字符串有非常详细的说明,因此,这里我只对常用的一些格式进行说明,首先请看下表:
d
月中的某一天
一位数的日期没有前导零
dd
月中的某一天
一位数的日期有一个前导零
ddd
周中某天的缩写名称
在 AbbreviatedDayNames 中定义
dddd
周中某天的完整名称
在 DayNames 中定义
M
月份数字
一位数的月份没有前导零
MM
月份数字
一位数的月份有一个前导零
MMM
月份的缩写名称
在 AbbreviatedMonthNames 中定义
MMMM
月份的完整名称
在 MonthNames 中定义
y
不包含纪元的年份
如果不包含纪元的年份小于 10,则显示不具有前导零的年份
yy
不包含纪元的年份
如果不包含纪元的年份小于 10,则显示具有前导零的年份
yyyy
包括纪元的四位数的年份
h
12 小时制的小时
一位数的小时数没有前导零
hh
12 小时制的小时
一位数的小时数有前导零
H
24 小时制的小时
一位数的小时数没有前导零
HH
24 小时制的小时
一位数的小时数有前导零
m
分钟
一位数的分钟数没有前导零
mm
分钟
一位数的分钟数有一个前导零
s
秒
一位数的秒数没有前导零
ss
秒
一位数的秒数有一个前导零
为了便于大家的理解,不妨试试下面的程序:
TestDateTimeToString() { DateTime now = DateTime.Now; format; .textBox1.Text = ; format = ; .textBox1.AppendText(format + + now.ToString(format) + ); format = ; .textBox1.AppendText(format + + now.ToString(format) + ); }
这段程序将输出结果:
yyyy-MM-dd HH:mm:ss: 2002-08-26 17:03:04
yy年M日d日: 02年8日26日
这时候,又出现一个问题,如果要输出的文本信息中包含格式字符怎么办?如
format = "year: yyyy, month: MM, day: dd";
this.textBox1.AppendText(now.ToString(format) + "\n");
将输出:
2ear: 2002, 4on下5: 08, 26a2: 26
这并不是我想要的结果,怎么办呢?有办法——
format = "\"year\": yyyy, \'month\': MM, \'day\': dd";
this.textBox1.AppendText(now.ToString(format) + "\n");
看,这次运行结果对了:
year: 2002, month: 08, day: 26
可以看出,只需要使用单引号或者双引号将文本信息括起来就好。