我必须通过c#类(如datetime)将此时间格式字符串(20130221191038.576375+330)
转换为正常日期时间。
请分享转换此想法的想法..
答案 0 :(得分:0)
答案 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()