Making a datetime vector with a leap year

Hi all
I have some code making a 8760x1 datetime vector containing every hour of the year
dt = datetime(2021,1,1:365);
et = hours(0:23)';
t = repmat(dt,length(et),1) + repmat(et,1,length(dt));
t=t(:);
'01-Jan-2021 00:00:00'
'01-Jan-2021 01:00:00'
'01-Jan-2021 02:00:00'
'01-Jan-2021 03:00:00'
'01-Jan-2021 04:00:00'
'01-Jan-2021 05:00:00'
'01-Jan-2021 06:00:00'
'01-Jan-2021 07:00:00'
'01-Jan-2021 08:00:00'
However some years are leap years. So if it is a leap year I want the 29 of February to be inserted properly. Like:
if length(Data{:,1})==422 %regular year
dt = datetime(2021,1,1:365);
et = hours(0:23)';
t = repmat(dt,length(et),1) + repmat(et,1,length(dt));
t=t(:);
elseif length(Data{:,1})==423 %leap year
"The code I am asking for"
end

Antworten (2)

Fangjun Jiang
Fangjun Jiang am 5 Apr. 2023
Bearbeitet: Fangjun Jiang am 5 Apr. 2023
Do it directly by specifying the starting and ending datetime.
d1=datetime(2021,1,1,0,0,0);
d2=datetime(2021,12,31,23,0,0);
size(d1:hours(1):d2)
ans = 1×2
1 8760

3 Kommentare

Joel
Joel am 5 Apr. 2023
A leap year has 8784 hours (1 day more). I want
'29-Feb-2021 00:00:00'
....
'29-Feb-2021 23:00:00'
to be inserted into the datetime vector t
Yes, a leap year does have 8784 hours. But 2021 is not a leap year. 2024 is:
d1=datetime(2024,1,1,0,0,0);
d2=datetime(2024,12,31,23,0,0);
size(d1:hours(1):d2)
ans = 1×2
1 8784
2021 was not a leap year. But as an example, 2020 was a leap year.
y = 2020;
d1=datetime(y,1,1,0,0,0)
d1 = datetime
01-Jan-2020
d2=datetime(y,12,31,23,0,0)
d2 = datetime
31-Dec-2020 23:00:00
size(d1:hours(1):d2)
ans = 1×2
1 8784
Another way to create d2 would be to shift d1 to the start of the next year then subtract an hour. This way the year information only appears in one place in the code, in the definition of d1.
d2Alternate = dateshift(d1, 'start', 'year', 'next') - hours(1)
d2Alternate = datetime
31-Dec-2020 23:00:00
d2 == d2Alternate
ans = logical
1

Melden Sie sich an, um zu kommentieren.

Stephen23
Stephen23 am 5 Apr. 2023
Bearbeitet: Stephen23 am 5 Apr. 2023
D = datetime(2021,1,1);
V = D:hours(1):D+calyears(1)-minutes(1);
size(V)
ans = 1×2
1 8760
D = datetime(2020,1,1);
V = D:hours(1):D+calyears(1)-minutes(1);
size(V)
ans = 1×2
1 8784

Kategorien

Mehr zu Programming finden Sie in Hilfe-Center und File Exchange

Produkte

Version

R2023a

Gefragt:

am 5 Apr. 2023

Kommentiert:

am 5 Apr. 2023

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by