How to write a timetable to excel with rowtimes as dates without times?
    12 visualizzazioni (ultimi 30 giorni)
  
       Mostra commenti meno recenti
    
Take this simple example:
m = (1:3)';
dates = datetime(2025,m,15);
tt = timetable(dates,m);
writetimetable(tt,'tt.xlsx')
tt is a 3x1 timetable with dates but no times 00:00:
        dates      m
    ___________    _
    15-Jan-2025    1
    15-Feb-2025    2
    15-Mar-2025    3
But the resulting excel sheet tt.xlsx includes the times 00:00:
    dates                   m    
    1/15/25 00:00      1    
    2/15/25 00:00      2    
    3/15/25 00:00      3 
How can I make writetimetable create an excel sheet with dates but no times 00:00?
0 Commenti
Risposta accettata
  Star Strider
      
      
 il 4 Lug 2025
        That is likely a problem with Excel.  
MATLAB writes the timetable correctly -- 
m = (1:3)';
dates = datetime(2025,m,15)
tt = timetable(dates,m);
writetimetable(tt,'tt.xlsx')
TT1 = readtimetable('tt.xlsx')
(I am using Ubuntu 24.04 so I do not have Excel or access to it.)  
.
12 Commenti
  Star Strider
      
      
 il 5 Lug 2025
				
  Jeremy Hughes
    
 il 11 Ago 2025
				I'll confirm that the format that Excel is applying here is out of MATLAB's control. The PreserveFormat argument should work on a Mac, but has no effect on the date format, unfortunately. 
Più risposte (3)
  Chuguang Pan
      
 il 4 Lug 2025
        
      Modificato: Chuguang Pan
      
 il 4 Lug 2025
  
      You can use "InputFormat" option to specify the date format
m = (1:3).';
dates = datetime(2025,m,15,"InputFormat","dd-MM-yyyy");
tt = timetable(dates,m);
writetimetable(tt,'TT.xlsx');
readtimetable('TT.xlsx')
1 Commento
  Dyuman Joshi
      
      
 il 4 Lug 2025
				
      Modificato: Dyuman Joshi
      
      
 il 4 Lug 2025
  
			This does not work. The problem is with the excel that saves the data - Open the excel and you'd find the issue OP is facing.
  Paul
      
      
 il 5 Lug 2025
        "If there was a way in Matlab to change the format in the first column in the excel file from "m/d/yy hh:mm" to "d-mmm-yyyy", my problem would be solved."
Seems like you might be able to define an empty .xlsx file that has the first column, starting from the second row, have the format you want. Call it empty.xlsx. Then when you want to write, copyfile empty.xlsx to the filename you want, and then use writetimetable with PreserveFormat and UseExcel both set to true.  I didn't test this approach.
3 Commenti
  Paul
      
      
 il 6 Lug 2025
				Interesting. Works for me.  Windows 11. Matlab 2024a.
>> copyfile empty.xlsx tt.xlsx
>> m = (1:3)';
>> dates = datetime(2025,m,15);
>> tt = timetable(dates,m);
>> writetimetable(tt,'tt.xlsx','PreserveFormat',true,'UseExcel',true);

  Walter Roberson
      
      
 il 7 Lug 2025
        For MacOS and Linux, it is not possible to PreserveFormat . 
About the best you can do on MacOS is to convert the timetable to a table, set the Format property of the appropriate column of the table to something like 'dd-MMM-uuuu', then set the appropriate column to be string() of the appropriate column. This will convert the column to the text in dd-MMM-uuuu format. 
Unfortunately it is likely that Excel will then interpret the column as text rater than as datetime format.
3 Commenti
  Paul
      
      
 il 25 Ago 2025
				According to @Jeremy Hughes in this comment, PreserveFormat should work on Mac, but perhaps with no capability to format dates.
Vedere anche
Categorie
				Scopri di più su Spreadsheets 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!







