conversion of seconds to date
8 views (last 30 days)
Show older comments
I have some time data in which time:units = "seconds since 2005-01-01". I would like to convert this seconds to datevc.
I have tried time= datenum(double(timeTm)/86400 + datenum([year month day hour minute second])); but some how I get result date 3 year ahed. ( instead of 2005 it shows me 2008).
1 Comment
Rick Rosson
on 1 Aug 2011
Can you please show more of your MATLAB code? Ideally, please post a set of complete, working code that we can run in MATLAB.
Thanks!
Accepted Answer
Fangjun Jiang
on 1 Aug 2011
It worked for me.
>> t=86400;
datestr(t/86400+datenum(2005,1,1))
ans =
02-Jan-2005
>> datestr(t/86400+datenum(2005,1,1,0,0,0))
ans =
02-Jan-2005
0 Comments
More Answers (1)
Kelly Kearney
on 1 Aug 2011
Your code looks like it should work. Have you verified that your data uses actual dates, with leap years, as opposed to a 365-day calendar? The latter could cause your results to be off by a few days, though three years seems like a different problem.
Also, are you certain the data is supposed to fall in the year 2005, rather than 2008? All your time values are less than 31536000? Just because the data uses 2005 as a reference year doesn't necessarily mean the data is located in that year.
0 Comments
See Also
Categories
Find more on Dates and Time in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!