[C#] Unix 타임 스탬프를 DateTime으로 또는 그 반대로 변환하려면 어떻게해야합니까?

이 예제 코드가 있지만 밀리 초 / 나노 초 문제에 대해 이야기하기 시작합니다.

C #의 Unix 시대 이후의 MSDN, Seconds 에도 같은 질문이 있습니다.

이것이 내가 지금까지 얻은 것입니다.

public Double CreatedEpoch
{
  get
  {
    DateTime epoch = new DateTime(1970, 1, 1, 0, 0, 0, 0).ToLocalTime();
    TimeSpan span = (this.Created.ToLocalTime() - epoch);
    return span.TotalSeconds;
  }
  set
  {
    DateTime epoch = new DateTime(1970, 1, 1, 0, 0, 0, 0).ToLocalTime();
    this.Created = epoch.AddSeconds(value);
  }
}



답변

필요한 것은 다음과 같습니다.

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;
}

또는 Java의 경우 (타임 스탬프가 초가 아닌 밀리 초이기 때문에 다릅니다) :

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;
}


답변

.NET (V4.6)의 최신 버전을 추가했다 내장 된 유닉스 시간 변환을 지원합니다. 여기에는 초 또는 밀리 초로 표시되는 유닉스 시간과 출발 시간이 모두 포함됩니다.

  • UTC까지의 유닉스 시간 (초) DateTimeOffset:
DateTimeOffset dateTimeOffset = DateTimeOffset.FromUnixTimeSeconds(1000);
  • DateTimeOffset 초 단위의 유닉스 시간 :
long unixTimeStampInSeconds = dateTimeOffset.ToUnixTimeSeconds();
  • 밀리 초 단위의 유닉스 시간 (UTC) DateTimeOffset:
DateTimeOffset dateTimeOffset = DateTimeOffset.FromUnixTimeMilliseconds(1000000);
  • DateTimeOffset 밀리 초 단위의 유닉스 시간 :
long unixTimeStampInMilliseconds = dateTimeOffset.ToUnixTimeMilliseconds();

참고 :이 메소드는 UTC와 변환합니다 DateTimeOffset. DateTime표현 을 얻으려면 단순히 DateTimeOffset.UtcDateTime또는 DateTimeOffset.LocalDateTime속성을 사용하십시오 .

DateTime dateTime = dateTimeOffset.UtcDateTime;


답변

DateTime에서 UNIX 타임 스탬프까지 :

public static double DateTimeToUnixTimestamp(DateTime dateTime)
{
    return (TimeZoneInfo.ConvertTimeToUtc(dateTime) -
           new DateTime(1970, 1, 1, 0, 0, 0, 0, System.DateTimeKind.Utc)).TotalSeconds;
}


답변

에서 위키 백과 :

UTC는 계절의 변화에 ​​따라 변경되지 않지만 시간대 관할 구역에서 일광 절약 시간 (서머 타임)을 준수하면 현지 시간 또는 시민 시간이 변경 될 수 있습니다. 예를 들어, 미국 동부 해안의 현지 시간은 겨울에는 UTC보다 5 시간이지만 일광 절약 시간은 4 시간입니다.

그래서 이것은 내 코드입니다.

TimeSpan span = (DateTime.UtcNow - new DateTime(1970, 1, 1, 0, 0, 0, 0,DateTimeKind.Utc));
double unixTime = span.TotalSeconds;


답변

밀리 초보다 높은 정밀도가 필요한 경우주의하십시오!

.NET (v4.6) 메소드 (예 : FromUnixTimeMilliseconds )는이 정밀도를 제공하지 않습니다.

AddSecondsAddMilliseconds 도 마이크로 초를 두 배로 줄였습니다.

이 버전은 높은 정밀도를 가지고 있습니다.

유닉스-> 날짜 / 시간

public static DateTime UnixTimestampToDateTime(double unixTime)
{
    DateTime unixStart = new DateTime(1970, 1, 1, 0, 0, 0, 0, System.DateTimeKind.Utc);
    long unixTimeStampInTicks = (long) (unixTime * TimeSpan.TicksPerSecond);
    return new DateTime(unixStart.Ticks + unixTimeStampInTicks, System.DateTimeKind.Utc);
}

DateTime-> 유닉스

public static double DateTimeToUnixTimestamp(DateTime dateTime)
{
    DateTime unixStart = new DateTime(1970, 1, 1, 0, 0, 0, 0, System.DateTimeKind.Utc);
    long unixTimeStampInTicks = (dateTime.ToUniversalTime() - unixStart).Ticks;
    return (double) unixTimeStampInTicks / TimeSpan.TicksPerSecond;
}


답변

IdentityModel.EpochTimeExtensions를 참조하십시오.

public static class EpochTimeExtensions
{
    /// <summary>
    /// Converts the given date value to epoch time.
    /// </summary>
    public static long ToEpochTime(this DateTime dateTime)
    {
        var date = dateTime.ToUniversalTime();
        var ticks = date.Ticks - new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc).Ticks;
        var ts = ticks / TimeSpan.TicksPerSecond;
        return ts;
    }

    /// <summary>
    /// Converts the given date value to epoch time.
    /// </summary>
    public static long ToEpochTime(this DateTimeOffset dateTime)
    {
        var date = dateTime.ToUniversalTime();
        var ticks = date.Ticks - new DateTimeOffset(1970, 1, 1, 0, 0, 0, TimeSpan.Zero).Ticks;
        var ts = ticks / TimeSpan.TicksPerSecond;
        return ts;
    }

    /// <summary>
    /// Converts the given epoch time to a <see cref="DateTime"/> with <see cref="DateTimeKind.Utc"/> kind.
    /// </summary>
    public static DateTime ToDateTimeFromEpoch(this long intDate)
    {
        var timeInTicks = intDate * TimeSpan.TicksPerSecond;
        return new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc).AddTicks(timeInTicks);
    }

    /// <summary>
    /// Converts the given epoch time to a UTC <see cref="DateTimeOffset"/>.
    /// </summary>
    public static DateTimeOffset ToDateTimeOffsetFromEpoch(this long intDate)
    {
        var timeInTicks = intDate * TimeSpan.TicksPerSecond;
        return new DateTimeOffset(1970, 1, 1, 0, 0, 0, TimeSpan.Zero).AddTicks(timeInTicks);
    }
}


답변

ScottCher의 답변을 보충하기 위해 최근에 입력 데이터 세트에 UNIX 타임 스탬프가 임의로 혼합되는 초와 밀리 초가 모두있는 성가신 시나리오에서 나 자신을 발견했습니다. 다음 코드는 이것을 잘 처리하는 것 같습니다.

static readonly DateTime UnixEpoch = new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc);
static readonly double MaxUnixSeconds = (DateTime.MaxValue - UnixEpoch).TotalSeconds;

public static DateTime UnixTimeStampToDateTime(double unixTimeStamp)
{
   return unixTimeStamp > MaxUnixSeconds
      ? UnixEpoch.AddMilliseconds(unixTimeStamp)
      : UnixEpoch.AddSeconds(unixTimeStamp);
}