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

2 views (last 30 days)
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?

Answers (2)

dpb
dpb on 7 May 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 on 7 May 2018
Edited: Jan on 7 May 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 Comments
Mads
Mads on 8 May 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 on 8 May 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.

Sign in to comment.

Categories

Find more on Dates and Time in Help Center and File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!