selecting columns with certain time period and placing in new array
3 次查看(过去 30 天)
显示 更早的评论
Hi there,
I have a data file ranging from 1974 to 2019 and I would like to select the data that corresponds to the period 2003/01/01 to 2009/12/31 and create another array (not sure if thats the right term).
Currently column 1,2 & 3 indicate year, month and day. But preferably would want to put this into a datenum() and create a serial date number.
If anyone has any idea how to this, any help would be greatly appreciated. I've attached the matlab file.
Kind regards,
Sophie
0 个评论
回答(1 个)
Bob Thompson
2019-8-19
In general, I would make an effort to extract the data using logic indexing. You can certainly convert the mdy into a datetime variable, but if you're looking to sort by each year it is not necessary.
I have not looked at your attached file (it's a limitation on my end), so the specific designations are probably off in the example. Adjust as needed.
data = mjo_data(mjo_data(:,1)==[2003:2009],:);
time = datetime(data(:,1:3))
2 个评论
Bob Thompson
2019-8-20
The error was likely because it was trying to find elements which matched the entire array, which is a logic error on my part. Your alternative solution would be correct.
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Time Series Objects 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!