Advice needed with the dateshift function

2 visualizaciones (últimos 30 días)
Michael T
Michael T el 12 de Abr. de 2019
Respondida: Steven Lord el 27 de Jul. de 2020
I'm struggling with the dateshift function and need some help if anyone can offer it.
I need to write some code that, once a menu option is chosen, will provide the next of two dates. i.e. If option 1 is selected on the menu, then either the next sunday date is displayed or the next wednesday date, whichever is nearest.
I can display the next sunday date, AND the next wednesday date, but i can't display the next sunday OR the next wednesday.
  1 comentario
Michael T
Michael T el 12 de Abr. de 2019
Here is the code i have been using. I'm not an expert so i understand there may be an easier way to do this.
t = datetime('today');
t = datetime;
if Menu == 1
Sunday = dateshift(t,'dayofweek','Sunday',1)
end
if Menu == 2
Wednesday = dateshift(t,'dayofweek','Wednesday',1)
end
if Menu == 3
Next_Day_Is = dateshift(t,'dayofweek','Sunday','Wednesday',1)
end

Iniciar sesión para comentar.

Respuestas (3)

Walter Roberson
Walter Roberson el 12 de Abr. de 2019
days_to_shift_Sw = [0 2 1 0 3 2 1]
days_to_shift_Sw( day(t, 'dayofweek') )
  4 comentarios
Michael T
Michael T el 13 de Abr. de 2019
If it’s already Sunday then the date can stay Sunday. It’s really more if it’s monday or Thursday for example.
Walter Roberson
Walter Roberson el 13 de Abr. de 2019
Okay, so just add the indicated number of days to the current day.

Iniciar sesión para comentar.


AMAN GARG
AMAN GARG el 27 de Jul. de 2020
dayshift(x,'Start','Hour')

Steven Lord
Steven Lord el 27 de Jul. de 2020
N = datetime('today')
W = dateshift(N, 'dayofweek', 'Wednesday')
S = dateshift(N, 'dayofweek', 'Sunday')
answer = min(W, S)

Categorías

Más información sobre Dates and Time en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by