SPListItem.Properties DateTime字段采用奇怪的Hex格式

stl*_*nce 3 sharepoint

有谁知道如何将这些字符串十六进制值转换回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());
    }
}
Run Code Online (Sandbox Code Playgroud)

小智 7

我最近发现这似乎只发生在Office 2007文档上(对于其他文件类型,值是日期的标准字符串格式).答案是十六进制值表示自1/1/1600以来的刻度数.这是一个适合我的转换:

Dim dateVal as DateTime = New DateTime(Long.Parse(dateText.Replace("0x","").Replace("|",""),System.Globalization.NumberStyles.HexNumber)).AddYears(1600)