C#时间戳转DateTime

这篇博客主要讨论了如何在C#中将时间戳转换为DateTime,包括Unix初始时间+时间戳的方法,以及使用DateTimeOffset的方式。作者提到.NET v4.6后内置了时间戳转换工具,简化了转换过程。

吐槽一句:国内的C#和Unity相关的有些博主实在是太懒了,同样的文章到处复制,导致中文搜索出来的第一页至少50%都是重复的内容…

正文分割线

C#中时间戳转DateTime有两种方式:

Unix初始时间+时间戳

  • Unix时间戳转DateTime
public static DateTime UnixTimeStampToDateTime( double unixTimeStamp )
{
    // Unix timestamp is seconds past epoch
    System.DateTime dtDateTime = new DateTime(1970,1,1,0,0,0,0,System.DateTimeKind.Utc);
    dtDateTime = dtDateTime.AddSeconds( unixTimeStamp ).ToLocalTime();
    return dtDateTime;
}
  • Unix毫秒时间戳转DateTime
public static DateTime JavaTimeStampToDateTime( double javaTimeStamp )
{
    // Java timestamp is milliseconds past epoch
    System.DateTime dtDateTime = new DateTime(1970,1,1,0,0,0,0,System.DateTimeKind.Utc);
    dtDateTime = dtDateTime.AddMilliseconds( javaTimeStamp ).ToLocalTime();
    return dtDateTime;
}

使用DateTimeOffset

  • .Net v4.6之后增加了内建的时间戳转换工具,很方便
public static DateTime TimeStampToDateTime( long timeStamp, bool inMilli = false)
    {
        DateTimeOffset dateTimeOffset = inMilli ? DateTimeOffset.FromUnixTimeMilliseconds(timeStamp) : DateTimeOffset.FromUnixTimeSeconds(timeStamp);
        return dateTimeOffset.LocalDateTime;
    }
不同的编程语言和环境下,将时间戳换为DateTime格式数据的方法有所不同,以下是几种常见的实现方式: ### JavaScript 在JavaScript中,可以使用`Date`对象来将时间戳换为指定格式的日期字符串。以下是一个示例函数: ```javascript function changeDateFormat(cellval) { var dateVal = cellval + ""; if (cellval != null) { var date = new Date(parseInt(dateVal.replace("/Date(", "").replace(")/", ""), 10)); var month = date.getMonth() + 1 < 10 ? "0" + (date.getMonth() + 1) : date.getMonth() + 1; var currentDate = date.getDate() < 10 ? "0" + date.getDate() : date.getDate(); return date.getFullYear() + "-" + month + "-" + currentDate; } } ``` 该函数接收一个时间戳作为参数,返回一个格式为`YYYY-MM-DD`的日期字符串[^1]。 ### SQL Server 在SQL Server中,可以使用`DATEADD`函数将时间戳换为DateTime格式。由于GMT是中央时区,北京在东8区,相差8个小时,因此需要加上8小时的偏移量: ```sql SELECT DATEADD(hour, 8, DATEADD(ss, 时间戳, '1970-01-01')); ``` 这里的`时间戳`是指从1970年1月1日开始的秒数[^2]。 ### Python 在Python中,可以使用`datetime`模块的`fromtimestamp`方法将时间戳换为DateTime对象,并使用`strftime`方法将其格式化为指定的字符串: ```python import datetime def change_time(date_int): return datetime.datetime.fromtimestamp(date_int).strftime("%Y-%m-%d %H:%M:%S.%f") if __name__ == '__main__': date_int = 1619308806.1234 print(change_time(date_int)) ``` 该代码定义了一个`change_time`函数,接收一个时间戳作为参数,返回一个格式为`YYYY-MM-DD HH:MM:SS.ffffff`的日期字符串[^3]。 ### C#C#中,可以使用以下代码将18位数字时间戳换为DateTime对象: ```csharp DateTime dateTimeStart = TimeZone.CurrentTimeZone.ToLocalTime(new DateTime(1970, 1, 1)); long lTime = long.Parse(timeStamp + "0000000"); TimeSpan toNow = new TimeSpan(lTime); DateTime result = dateTimeStart.Add(toNow); ``` 其中`timeStamp`是18位数字时间戳[^4]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值