Replacing cells in a cell array/Dealing with AM and PM using datenum
1 visualización (últimos 30 días)
Mostrar comentarios más antiguos
Kendra Wright
el 24 de Nov. de 2014
Comentada: Star Strider
el 24 de Nov. de 2014
I'm creating a time stamp by converting my time and date using datenum(). Now I have the issue of the AM and PM. My thought was to run the cell array through for loop, testing to see if the string matches "PM." Which returns a 1 if true and 0 if false. Then say if it is equal to 1, force that cell in the array to equal 12, if not then equal to 0. I have a large data set right now which is made of cell arrays called Data and the third cell array is the AM and PM part. This is my code right now:
for i=1:l3
tf = strcmp(Data{1,3}{i,1},'AM')
if tf == 1
Data{1,3}{i,1} = 0;
else if tf == 1
Data{3,i}{i,1} = 12
end
end
end
It runs through the loop and tests the strings correctly but I've made an error with rewriting that array because it isn't actually changing the array. It just returns the original with the AM and PM. I want it to have either 0 or 12.
0 comentarios
Respuesta aceptada
Star Strider
el 24 de Nov. de 2014
DS = ['11/24/2014 9:30 AM'; '11/24/2014 9:30 PM'];
DN = datenum(DS, 'mm/dd/yyyy HH:MM AM');
DV = datevec(DN);
See formatIn under ‘Input Arguments’ for details.
2 comentarios
Más respuestas (1)
Andrew Reibold
el 24 de Nov. de 2014
Editada: Andrew Reibold
el 24 de Nov. de 2014
I'm really confused as to why you have Data{1,3}{i,1} for the first assignment, and Data{3,i}{i,1} for the second one. Shouldn't these both be the same? Could this be your issue?
Also, maybe try entering your numbers as STRINGS. Use the parenthesis.
Also, you can put strcmp directly into the if statement if that helps you clean stuff up.
Here is an example. You may need to tune it up.
for i=1:l3
if strcmp(Data{1,3}{i,1},'AM')
Data{1,3}{i,1} = '0';
else if strcmp(Data{1,3}{i,1},'PM')
Data{1,3}{i,1} = '12'
end
0 comentarios
Ver también
Categorías
Más información sobre Dates and Time 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!