将时间格式转换为正常日期时间

时间:2013-02-22 05:56:39

标签: c# datetime

我必须通过c#类(如datetime)将此时间格式字符串(20130221191038.576375+330)转换为正常日期时间。

请分享转换此想法的想法..

3 个答案:

答案 0 :(得分:0)

谢谢大家,在Erik,董和BlackHatShadow的帮助下,我得到了我的要求的解决方案。

Referred this

this also

答案 1 :(得分:0)

您拥有的格式是CIM_DATETIME值,几乎很容易解析。唯一的问题是它将时区指定为分钟数的偏移量。

您可以使用DateTime.TryParseExact在时区说明符之前转换字符串部分,然后从结果中减去时区值(以分钟为单位)以获取UTC日期时间。然后,如果需要,您可以转换为本地时间,或以UTC格式保留。

public static DateTime? CIMToUTCDateTime(string CIM_DATETIME)
{
    // CIM_DATETIME must be 25 characters in length
    if (string.IsNullOrEmpty(CIM_DATETIME) || CIM_DATETIME.Length != 25)
        return null;

    // Get the datetime portion of the string without timezone offset
    string dtPortion = CIM_DATETIME.Substring(0, 21);

    // convert to datetime
    DateTime dt;
    if (!DateTime.TryParseExact(dtPortion, "yyyyMMddHHmmss.ffffff", System.Globalization.DateTimeFormatInfo.InvariantInfo, System.Globalization.DateTimeStyles.AssumeUniversal | System.Globalization.DateTimeStyles.AdjustToUniversal, out dt))
        return null;

    // subtract timezone offset to get UTC time equivalent
    int tzoffset;
    if (!Int32.TryParse(CIM_DATETIME.Substring(21), out tzoffset))
        return null;
    dt = dt.AddMinutes(-tzoffset);

    // return UTC datetime
    return dt;
}

现在我写了这个可怕的小方法,你已经走了,找到了另一个解决方案。典型:P

答案 2 :(得分:0)

我知道你已经找到了一个解决方案,但我遇到了这个很好的ManagementDateTimeConverter .Net类,它可以完全满足您的需求。您所需要做的就是:

// This gets converted to your local time
DateTime converted = ManagementDateTimeConverter.ToDateTime("20130221191038.576375+330")

// If you want the UTC equivalent:
converted.ToUniversalTime()