InputFormat not working when reading excel dates with readtable
6 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Catherine
le 28 Mar 2025
Commenté : Catherine
le 28 Mar 2025
I have gotten this to work using xlsread, but I see it is not recommended, so I would like to sort this issue out.
I made a simple excel file, testfile.xlsx, that has a date field that is in european time. The date is 1Sep2025. I'm trying to get it into Matlab (2023a or 2023b) using readtable.
f1 = ['Q:\testfile.xlsx'];
opts = detectImportOptions(f1);
opts = setvaropts(opts,'FieldDT','InputFormat','dd/MM/yyyy HH:mm');
opts = setvaropts(opts,'FieldDT','DateTimeFormat','MMM dd yyyy HH:mm:ss');
R1 = readtable(f1,opts)
Here is my output:
R1 =
1×4 table
FieldDT A B C
____________________ _ _ ________
Jan 09 2025 11:12:00 1 2 {'Frog'}
When I switch the InputFormat to 'MM/dd/yyyy HH:mm' it still gives me this same output, which does not make any sense to me. I have even changed the DatetimeLocale to 'de_DE' and 'en_GB' without any difference in output.
0 commentaires
Réponse acceptée
Walter Roberson
le 28 Mar 2025
The first field of the file is not text that can be parsed. The first field of the file is in Excel numeric format, which is "seconds since Jan 1, 1900". The display formatting applied to the cell converts the numeric value to display date and time.
Plus de réponses (0)
Voir également
Catégories
En savoir plus sur Spreadsheets dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!