Exclude certain dates on x-axis using xlim or xtick?
Ältere Kommentare anzeigen
I have attached my dataset and a plot to illustrate what I am trying to do. I would like to remove the blank spaces between the data to account for the fact that no data was collected between 5pm-8am. It would be useful to mark the boundary of each new day with a vertical line. Is there a way to do this?
% Create datasets for plotting (from y.mat)
backg = y(:,2);
backg(y(:,4)~=0) = NaN;
inter = y(:,2);
inter(y(:,4)<1) = NaN;
y_dt=datetime(y(:,1),'ConvertFrom','datenum');
% Plot
figure(1)
bar(y_dt,backg,'g')
hold on
bar(y_dt,inter,'r')
plot(y_dt,y(:,3),'black'); %plot threshold
xlim([datetime(2020,2,5,08,0,0), datetime(2020,2,7,17,0,0)]); %filter to date range of interest
2 Kommentare
dpb
am 22 Okt. 2021
Not with the real datetime on the x-axis, no.
There are ways to work around the problem by plotting against ordinal values (which won't work if the time points aren't uniform) or by using datenum time-of-day and an arbitrary date and then fix up the tick labels manually.
All in all, it's a royal p(ain)it(proverbial)a(ppendage).
Louise Wilson
am 22 Okt. 2021
Akzeptierte Antwort
Weitere Antworten (0)
Kategorien
Mehr zu Dates and Time finden Sie in Hilfe-Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!