How to plot Date time series in MATLAB?
Mostrar comentarios más antiguos
I am facing difficulties in plotting my time series data.The data file is also attached.I write code like this but doesnt work.
data3=readtable ('PRICE_AND_DEMAND_Jan.csv')
Date_Time = data3(:,2);
datecell=table2cell(Date_Time);
load = data3(:,3);
A = table2array(load)
p=datenum(datecell);
plot(datenum(datecell), A)
datetick('x', 'dd-mmm-yyyy HH:MM:SS')
% datetick('x', 'dd-mmm-yyyy HH:MM:SS')

3 comentarios
madhan ravi
el 15 de Feb. de 2019
Which version of matlab are you using?
Ali
el 16 de Feb. de 2019
Peter Perkins
el 17 de Feb. de 2019
You have dates like xx-yy-zz. That's kind of ambiguous. You'll want to provide a format.
Respuesta aceptada
Más respuestas (2)
Ricardo MF
el 15 de Feb. de 2019
0 votos
Are you running the entire code or assuming you already 'uploaded' the variables? The problem is with the format of your variable Date_Time that for some reason converted to a 'char' vector. Instead mine's not. When I convert to datecell, I do not have problems with datenum or datevec. Maybe this problem is related to the version of matlab as questioned by madhan ravi.

1 comentario
Ali
el 16 de Feb. de 2019
Peter Perkins
el 17 de Feb. de 2019
In something as recent as R2018b, stay away from datenum and datetick if possible. (Also, hardly ever does one need table2cell, brace subscripting would have done the same thing, but you don't want to do that thing anyway.)
Try this:
>> t = readtable('PRICE_AND_DEMAND_Jan.csv','Format','%s%{dd-MM-yy HH:mm}D%f%f%s');
>> t.REGION = categorical(t.REGION);
>> t.PERIODTYPE = categorical(t.PERIODTYPE);
>> head(t)
ans =
8×5 table
REGION SETTLEMENTDATE TOTALDEMAND RRP PERIODTYPE
______ ______________ ___________ _____ __________
NSW1 01-01-19 00:30 7457.6 66.95 TRADE
NSW1 01-01-19 01:00 7243.2 69.33 TRADE
NSW1 01-01-19 01:30 6918.6 72.8 TRADE
NSW1 01-01-19 02:00 6676.6 70.31 TRADE
NSW1 01-01-19 02:30 6513.2 66.98 TRADE
NSW1 01-01-19 03:00 6400 63.87 TRADE
NSW1 01-01-19 03:30 6317.4 62.2 TRADE
NSW1 01-01-19 04:00 6242.1 50.22 TRADE
>> plot(t.SETTLEMENTDATE,t.TOTALDEMAND);

4 comentarios
Ali
el 17 de Feb. de 2019
Peter Perkins
el 18 de Feb. de 2019
I doubt that you want the time on a plot that covers an entire month. But zoom in, and the times will appear when you get close enough. In any case, you can set the properties of the x axis to get exactly the date/time format that you want. get gca, and dig in to its properties.
%s%{dd-MM-yy HH:mm}D%f%f%s is a quick way to read the file and provide a format for the timestamps. More control is available using detectimportoptions.
Peter Perkins
el 21 de Feb. de 2019
You are going to need to post something more than that. That is not MATLAB code. In recent versions of MATLAB, all you need to do it set xlim with datetimes.
Categorías
Más información sobre Time Series Objects en Centro de ayuda y File Exchange.
Productos
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!


