Plot x axis in date format
5 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
I want to load and plot a dataset, with the x-axis in date format:

When I make my plot using the below code:
data=xlsread('XXX.xlsx');
Date=data(:,1); %week start date
Y=data(:,4);
plot(Date,Y,'ob');
But I get a strange x-axis

How can I change the x-axis to the date format in the excel? and then to a number in months?
3 comentarios
Peter Perkins
el 27 de Abr. de 2020
Based on your (I guess) screenshot of an excel spreadsheet, you have a mix of text and dates in that column of the spreadsheet. That's bad news. Strongly recommend that you clean that up before doing anything. Maybe you can clean it up in MATLAB, but better to deal with the source. I have no idea what you'd even get back in the numeric output from your call to xlsread.
Once you clean that up, stay away from xlsread, and use readtable. Depending on what version of MATLAB you are using, you may get datetimes automatically, or you may get text and have to convert. If you get a cell array that is a mix of text and numbers, you haven't cleaned up the file. In very recent versions of MATLAB, use readtimetable. At that point, you can just plot vs. the datetime. Muhammad shows that, although I think the file he's using is very different than what you have.
Respuestas (2)
Mehmed Saad
el 17 de Abr. de 2020
Take this as an example
T = readtable('Test.csv');
t= datetime(strrep(strrep(T.time,'T',' '),'Z',''));
figure,plot(t,T.long_E,'.')
In this example i converted the data i ve into time series so the plot is

1 comentario
Mehmed Saad
el 17 de Abr. de 2020
You can convert your excel datetime usinng the following format
datetime(Date,'Format','MM/dd/yyyy')
where Date must be in the form of string
Ameer Hamza
el 17 de Abr. de 2020
My answer here shows how to convert a numeric ruler on x-axis to a datetime ruler: https://www.mathworks.com/matlabcentral/answers/517403-set-the-startdate-and-enddate-of-x-axis-using-plot
Espically check the code in this comment: https://www.mathworks.com/matlabcentral/answers/517403-set-the-startdate-and-enddate-of-x-axis-using-plot#comment_827165
0 comentarios
Ver también
Categorías
Más información sobre Dates and Time en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!