[开发笔记]-unix时间戳、GMT时间与datetime类型时间之前的转换

简介:

前段时间项目中涉及到了MySql和MsSql数据类型之间的转换,最近又在研究新浪微博的API,涉及到了带有时区的GMT时间类型的转换,所以,特记录于此,以备日后查询。

一:UNIX时间戳与datetime时间之间的转换

1. 将Unix时间戳转换为DateTime类型时间

方法一:

复制代码
        /// <summary>
        /// 将Unix时间戳转换为DateTime类型时间
         /// </summary>
        /// http://www.cnblogs.com/babycool
        /// <param name="d"></param>
        /// <returns></returns>
        public static DateTime ConvertIntToDateTime(double d)
        {
            System.DateTime time = System.DateTime.MinValue;
            System.DateTime startTime = TimeZone.CurrentTimeZone.ToLocalTime(new System.DateTime(1970, 1, 1));
            time = startTime.AddSeconds(d);
            return time;
        }
复制代码

方法二:

复制代码
/// <summary>
        /// 将Unix时间戳转换为DateTime类型时间
        /// </summary>
        /// http://www.cnblogs.com/babycool
        /// <param name="time"></param>
        /// <returns></returns>
        static DateTime ConvIntToDateTime(long time)
        {
            DateTime timeStamp = new DateTime(1970, 1, 1);  //得到1970年的时间戳
            long t = (time + 8 * 60 * 60) * 10000000 + timeStamp.Ticks;
            DateTime dt = new DateTime(t);
            return dt;
        }
复制代码

2.在SQL Server Management Studio 中查询并转换:

--将Unix时间戳转换为dateline类型
select top 10  DATEADD(SS,regdate,'1970-01-01 00:00:00') from dbo.uc_members

 

3. 将DateTime时间格式转换为Unix时间戳格式

复制代码
/// <summary>
        ///  将DateTime时间格式转换为Unix时间戳格式
        /// </summary>
        /// http://www.cnblogs.com/babycool
        /// <param name="time"></param>
        /// <returns></returns>
        public static double ConvertDateTimeToInt(System.DateTime time)
        {
            double intResult = 0;
            System.DateTime startTime = TimeZone.CurrentTimeZone.ToLocalTime(new System.DateTime(1970, 1, 1));
            intResult = (time - startTime).TotalSeconds;
            return intResult;
        }
复制代码

 

二:将新浪微博中带有时区的GMT时间转换为DateTime

复制代码
/// <summary>
        /// 将新浪微博中带有时区的GMT时间转换为DateTime
        /// </summary>
        /// http://www.cnblogs.com/babycool
        /// <param name="dateString">微博时间字符串</param>
        /// <returns>DateTime</returns>
        public static DateTime ParseUTCDate(string dateString)
        {
            System.Globalization.CultureInfo provider = System.Globalization.CultureInfo.InvariantCulture;

            DateTime dt = DateTime.ParseExact(dateString, "ddd MMM dd HH:mm:ss zzz yyyy", provider);

            return dt;
        }
复制代码

 

三:转换效果:

相应代码:

复制代码
            //新浪微博返回的时间是带有时区的GMT时间,转换为datetime类型时间格式:

            // GMT时间: Tue May 31 17:46:55 +0800 2011
            Response.Write("将GMT时间转换为datetime类型时间:");
            Response.Write(ParseUTCDate("Tue May 31 17:46:55 +0800 2011").ToString());
            Response.Write("<br/>");

            //UNIX时间戳  1176686120
            Response.Write("将UNIX时间戳转换为datetime类型时间:");
            Response.Write(ConvertIntToDateTime(1176686120));
            Response.Write("<br/>");
            Response.Write("方法二:");
            Response.Write(ConvIntToDateTime(1176686120));
            Response.Write("<br/>");
            Response.Write("将datetime类型时间转换为UNIX时间戳:");
            Response.Write(ConvertDateTimeToInt(ConvertIntToDateTime(1176686120)));
            Response.Write("<br/>");
复制代码
本文转自 酷小孩 博客园博客,原文链接: http://www.cnblogs.com/babycool/archive/2013/06/13/3134471.html   ,如需转载请自行联系原作者
相关文章
|
7月前
|
Unix
Unix时间戳1970Java与Unix时间戳互转
Unix时间戳1970Java与Unix时间戳互转
54 0
|
3月前
|
Unix C语言
UNIX操作系统的开发始于1969年
UNIX操作系统的开发始于1969年
76 5
|
5月前
|
Unix
鸿蒙将unix时间戳转换为string类型
鸿蒙将unix时间戳转换为string类型
99 0
|
Ubuntu Unix Python
[oeasy]python0024_unix时间戳_epoch_localtime_asctime_PosixTime_unix纪年法
[oeasy]python0024_unix时间戳_epoch_localtime_asctime_PosixTime_unix纪年法
107 2
|
Unix
遇到的各种时间类型:UTC时间、GMT时间、本地时间、Unix时间戳
每次遇到各种时间傻傻分不清,特意记录一下,给自己提个醒。
416 0
|
Unix API C语言
UNIX时间戳和北京时间的相互转换
UNIX时间戳和北京时间的相互转换
715 0
UNIX时间戳和北京时间的相互转换
|
关系型数据库 MySQL Unix
mysql,如何在Unix和Mysql时间戳之间进行转换?
mysql,如何在Unix和Mysql时间戳之间进行转换?
157 0
|
SQL 存储 Unix
【Hive】FROM_UNIXTIME() 和 UNIX_TIMESTAMP()时间戳函数用法
【Hive】FROM_UNIXTIME() 和 UNIX_TIMESTAMP()时间戳函数用法
1562 0
|
存储 前端开发 Unix
Mysql - 如何存储 10位、13位的 unix 时间戳?
Mysql - 如何存储 10位、13位的 unix 时间戳?
527 0
|
Unix 关系型数据库 MySQL
Unix时间戳
Unix时间戳
440 0