Replacing cells in a cell array/Dealing with AM and PM using datenum
2 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
Kendra Wright
il 24 Nov 2014
Commentato: Star Strider
il 24 Nov 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 Commenti
Risposta accettata
Star Strider
il 24 Nov 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 Commenti
Più risposte (1)
Andrew Reibold
il 24 Nov 2014
Modificato: Andrew Reibold
il 24 Nov 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 Commenti
Vedere anche
Categorie
Scopri di più su Dates and Time in Help Center e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!