What is the precision of *.datenum, which dir() returns

3 visualizaciones (últimos 30 días)
Mads
Mads el 7 de Mayo de 2018
Comentada: Jan el 8 de Mayo de 2018
When I apply dir() to a file I get a struct with folder, name, date, bytes, and also datenum. How many significant digits do I need to fully store the number correctly, e.g., when I need to compare two files...
Say I print the number to an ascii file: fprintf(fid,'%.xf',mystruct.datenum) what is x supposed to be?

Respuestas (2)

dpb
dpb el 7 de Mayo de 2018
datenum is a double; hence has 15-16 significant digits; the safest way to store it is as a double but you'll get as close as can with '%.16g'

Jan
Jan el 7 de Mayo de 2018
Editada: Jan el 7 de Mayo de 2018
The precision of the date depends on the file system. Linux' ext4 file system supports nanoseconds, NTFS uses 100 nanoseconds, FAT has a resolution of 2 seconds.
Under Windows FEX: GetFileTime can reply the native UINT64 file times:
T = GetFileTime(FileName, 'native')
T.Write
>> 131499596832223845
Using this integer avoids rounding and precision problems of the doubles used for Matlab's datenum format.
  2 comentarios
Mads
Mads el 8 de Mayo de 2018
Interesting discussion. What if a jpeg was captured on a Nikon or smartphone, and stored on a Linux system or mac? Do datenums get rounded when transfered?
Is there a getfiletime for matlab running on mac?
Jan
Jan el 8 de Mayo de 2018
There are two possibilities: Either moving the file keeps the dates, that the time is rounded to the precision of the file system. Or the function to move the file (e.g. the operating system) uses the current date as date of creation.

Iniciar sesión para comentar.

Categorías

Más información sobre File Operations en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by