日期型数据知识

简介:

日期型数据,在 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);

 

 

 

 

格式化日期型数据

编程的过程中,通常需要将日期型数据按照一定的格式输出,当然,输出结果肯定是

字符串。为此,我们需要使用 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 秒一位数的秒数有一个前导零

 

为了便于大家的理解,不妨试试下面的程序:

private void TestDateTimeToString()

{ DateTime now = DateTime.Now;

string format;

this.textBox1.Text = "";

format = "yyyy-MM-dd HH:mm:ss";

this.textBox1.AppendText(format + ": " +now.ToString(format) + "\n");

format = "yy 年M 日d 日";

this.textBox1.AppendText(format + ": " + now.ToString(format) +"\n");

}

这段程序将输出结果:

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

可以看出,只需要使用单引号或者双引号将文本信息括起来就好。

目录
相关文章
|
6月前
|
分布式计算 DataWorks 大数据
MaxCompute产品使用问题之月和日是1位数的日期格式如何转化成标准日期值
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
7月前
|
存储 Java 数据库连接
JDBC存储datetime型数据
JDBC存储datetime型数据
|
存储 JSON 前端开发
【MySQL笔记】数字类型、时间和日期类型、字符串类型
在数据库中,经常需要存储一些数字,适合用数字类型来保存。数字类型包括整数类型、浮点数类型、定点数类型、BIT(位)类型。
33507 1
【MySQL笔记】数字类型、时间和日期类型、字符串类型
|
Java 数据库
Java 中日期String类型与Date类型相互转化
插入数据库时,存入当前日期,需要格式转换
105 0
计算日期到天数转换
计算日期到天数转换
131 0
计算两个字符串类型的日期相差的天数或者小时数,计算日期字符串到今天的年龄
计算两个字符串类型的日期相差的天数或者小时数,计算日期字符串到今天的年龄
180 0
SAP MM 如何知道移动类型的字段选择和会计科目的字段选择是否不一致?
SAP MM 如何知道移动类型的字段选择和会计科目的字段选择是否不一致?
SAP MM 如何知道移动类型的字段选择和会计科目的字段选择是否不一致?