Why 'NaT' (class: datetime) does not work with find function?
4 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Atanu
el 1 de Jul. de 2022
Comentada: Star Strider
el 1 de Jul. de 2022
I have a table part of which is attached. The enries in the date column are as datetime. I am trying to get the id where the entry for date is NaT. When I use find function for regular dates such as,
idx = ans.id(find(ans.date == '19-Apr-2022'));
I get an output. But the same does not work for NaT.
idx = ans.id(find(ans.date == 'NaT'));
It gives me empty array. What might be the problem?
0 comentarios
Respuesta aceptada
Más respuestas (1)
Steven Lord
el 1 de Jul. de 2022
The reason why isnat works and your == call did not is because NaT is like NaN -- it is not equal to anything, not even another NaT or NaN. It is not even equal to itself.
x = [1 NaN 2]
x == x
isequal(x, x)
y = [NaT datetime('today')]
y == y
isequal(y, y)
You will need to identify the NaT values with isnat or ismissing.
isnat(y)
ismissing(y)
Alternately you could use isequaln if you want to detect if two arrays (potentially containing NaT) are equal. isequaln behaves like isequal except it considers missing values equal to missing values.
isequaln(y, y)
Ver también
Categorías
Más información sobre Calendar 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!