Isso pode ser devido ao fato de que o Excel armazena timestamps como "datas de automação OLE".
Do .NET DateTime.ToOADate
An OLE Automation date is implemented as a floating-point number whose integral component is the number of days before or after midnight, 30 December 1899, and whose fractional component represents the time on that day divided by 24. For example, midnight, 31 December 1899 is represented by 1.0; 6 A.M., 1 January 1900 is represented by 2.25; midnight, 29 December 1899 is represented by -1.0; and 6 A.M., 29 December 1899 is represented by -1.25.
The base OLE Automation Date is midnight, 30 December 1899. The minimum OLE Automation date is midnight, 1 January 0100. The maximum OLE Automation Date is the same as DateTime.MaxValue
, the last moment of 31 December 9999.
Os números de ponto flutuante processados em PCs estão sujeitos a erros de arredondamento mais ou menos graves, com algumas frações piores.
Um dia tem 24 * 60 * 60 = 86400
segundos no total.
(13 * 60 + 13) / 86400 = 0,00917824074074
(13 * 60 + 13 + 0,1282) / 86400 = 0,00917972453704
Como você pode ver, os números são muito semelhantes e só diferem a partir da 6ª casa decimal.