convert Julian Date to yyyy-mm-dd

102 visualizzazioni (ultimi 30 giorni)
Qiming Sun
Qiming Sun il 19 Ott 2020
Modificato: Stephen23 il 17 Lug 2023
I am analyzing the vertical profiles of the profiling robotic float ( ftp://ftp.ifremer.fr/ifremer/argo/dac/coriolis/6902905/ ). The dates are there stored as Julian Dates, field JULD. As I was converting them into format yyyy-mm-dd on Matlab, difficulties occurred. The Julian date used here is not as usual (first 2 digits year and last 3 digits days w.r.t. Jan 1st, nor the number of days w.r.t. 4713 BCE ). For example here 25856 represents 17-Oct-2020, which is confusing to me. Could someone please provide some instruction on this? Thank you very much!
  1 Commento
James Tursa
James Tursa il 19 Ott 2020
Can you explain how 25856 represents 17-Oct-2020? If the "first 2 digits year" is 25, how does that and 856 days result in a date in 2020?

Accedi per commentare.

Risposta accettata

meghannmarie
meghannmarie il 19 Ott 2020
Modificato: meghannmarie il 19 Ott 2020
Your number represents "days since 1950-01-01 00:00:00 UTC". Most netcdf times are stored like this, you need to look at attribute on the time field in the netcdf file to so see whether it is hours since or days since and the date of origin. To convert do this:
epoch = datetime(1950,01,01);
time = epoch + days(jd);
  1 Commento
Stephen23
Stephen23 il 17 Lug 2023
Modificato: Stephen23 il 17 Lug 2023
+1 Possibly CALDAYS is required:
D = datetime(1950,01,01, 'Format','u-MM-dd HH:mm:ss') + caldays(25856)
D = datetime
2020-10-16 00:00:00

Accedi per commentare.

Più risposte (1)

Adam Danz
Adam Danz il 19 Ott 2020
Modificato: Adam Danz il 23 Ott 2020
Are you looking for this?
datetime(25856,'convertfrom','juliandate','Format','yyy-MM-dd')
ans = datetime
4643-09-09
which makes sense given,
datetime(0,'convertfrom','juliandate','Format','yyy-MMM-dd') + days(25856)
ans = datetime
4643-Sep-09
Inspired by this answer.

Categorie

Scopri di più su Dates and Time in Help Center e File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by