有谁知道如何将这些字符串十六进制值转换回DateTime值?
属性my_DateProperty(System.String)= 0x01c9874e | 0x98f28800
//l_item is SPListItem Hashtable l_properties = l_item.Properties; if (l_properties != null) { object l_value = null; foreach (string l_key in l_properties.Keys) { l_value = l_properties[l_key]; Splogger.log("Property " + l_key + " (" + l_value.GetType().ToString() + ") = " + l_value.ToString()); } }
小智.. 7
我最近发现这似乎只发生在Office 2007文档上(对于其他文件类型,值是日期的标准字符串格式).答案是十六进制值表示自1/1/1600以来的刻度数.这是一个适合我的转换:
Dim dateVal as DateTime = New DateTime(Long.Parse(dateText.Replace("0x","").Replace("|",""),System.Globalization.NumberStyles.HexNumber)).AddYears(1600)
我最近发现这似乎只发生在Office 2007文档上(对于其他文件类型,值是日期的标准字符串格式).答案是十六进制值表示自1/1/1600以来的刻度数.这是一个适合我的转换:
Dim dateVal as DateTime = New DateTime(Long.Parse(dateText.Replace("0x","").Replace("|",""),System.Globalization.NumberStyles.HexNumber)).AddYears(1600)