手机
当前位置:查字典教程网 >编程开发 >asp.net教程 >12小时制和24小时制获取当天零点的问题探讨
12小时制和24小时制获取当天零点的问题探讨
摘要:最近在写定时服务的时候,要获取当天的零点这个时间,但是是这样获取的复制代码代码如下:DateTimedt=DateTime.Parse(Da...

最近在写定时服务的时候,要获取当天的零点这个时间,但是是这样获取的

复制代码 代码如下:

DateTime dt = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd")+" 00:00:00");

Console.WriteLine(dt.ToString("yyyy-MM-dd HH:mm:ss"));

在本地,测试,QA环境测试了均没有问题,但是上了公网服务器以后,这个定时服务,就出问题了;写了下日志,竟然发现获取当天的零点,拼起来后获取的时间是前一天的零点,原来服务器时间是12小时制的,本地环境都是24小时制的。

继续深究,发现每天的00:00:00到00:59:59这段时间,在24小时制时间内是当天的日期;但是在12小时制时间内,是前天的日期的12:00:00到12:59:59。举个例子,比如说按照24小时制时间,今天的“2013-09-26 00:00:00”这个时间,在12小时制服务器中,获取的话就是“2013-09-25 12:00:00”,DateTime.Now.ToString("yyyy-MM-dd")这个方法获得的日期就是“2013-09-25”,那么dt获取就是“2013-09-25 12:00:00”。

原来,根据C#中获取时间的小时制的不同,可以这样获取

复制代码 代码如下:

//24小时制:

DateTime dt = DateTime.Now;

string dt24 = dt.ToString("yyyy-MM-dd HH:mm:ss");

//12小时制:

DateTime dt = DateTime.Now;

string dt12 = dt.ToString("yyyy-MM-dd hh:mm:ss");

//是由H的大小写决定

不管服务器的时间制是12小时还是24小时,大写H获取的就是24小时的时间,小写h获取的就是12小时的时间。

【12小时制和24小时制获取当天零点的问题探讨】相关文章:

服务器读取EXCEL不安装OFFICE如何实现

ConfiguraionSource节点及多个配置文件的应用

ASP.NET 导出到Excel时保留换行的代码

SQL Server 2005 RTM 安装错误 :The SQL Server System Configuration Checker cannot be executed due to

asp.net 自动将汉字转换成拼音第一个字母

ASP.net(c#)打造24小时天气预报及实时天气

ASP.NET User Control使用技巧一则

浅谈ASP.NET中最简单的自定义控件

DataGrid同时具有分页和排序功能及注意点

ASP.NET 2005 Treeview终极解决方案

精品推荐
分类导航