zoukankan      html  css  js  c++  java
  • [开发笔记]-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/>");
    复制代码
  • 相关阅读:
    【xsy2506】 bipartite 并查集+线段树
    Linux K8s容器集群技术
    Linux 运维工作中的经典应用ansible(批量管理)Docker容器技术(环境的快速搭建)
    Linux Django项目部署
    Linux Django项目测试
    Linux 首先基本包安装(vim啊什么的),源,源优化,项目架构介绍, (LNMuWsgi)Django项目相关软件mysql,redies,python(相关模块)安装配置测试
    Linux centos系统安装后的基本配置,Linux命令
    Linux 虚拟机上安装linux系统 (ip:子网掩码,网关,dns,交换机,路由知识回顾)
    $ Django 调API的几种方式,django自定义错误响应
    $Django 路飞之显示视频,Redis存购物车数据,优惠卷生成表,优惠卷的一个领取表。(知识小回顾)
  • 原文地址:https://www.cnblogs.com/twodog/p/12139042.html
Copyright © 2011-2022 走看看