Datetime from csv: format change from 2017b to 2018 and higher
Show older comments
I have the following code to import data from csv file:
filename = '201810.csv';
scenariodata = readtable(filename, 'delimiter', ',');
Some of the data in the csv file is in date format HH:MM:SS, for example in field (3,8) the data is 3:32:11.
In Matlab 2017b, this field is imported as '3:32:11', whereas in newer versions it becomes just 3:32:11.
As a result, when I try
datetime(scenariodata{3,8},'InputFormat','HH:mm:ss','TimeZone','Asia/Tokyo')
I get the following error message:
"Error using datetime (line 639) Input data must be a numeric array, a string array, a cell array containing character vectors, or a char matrix.".
How should I change my code for newer Matlab versions?
Thank you!
Accepted Answer
More Answers (1)
Peter Perkins
on 30 Oct 2019
readtable now reads timestamps as datetimes by default. I think you have two options:
1) If you are already getting datetimes in your table, there's no need to call datetime to convert text to datetime. Just delete that line.
2) As Ben says, you can turn off the "datetime by default" with DatetimeType.
Your example code is converting one element of a table. I hope you aren't actualloy doing it that way: you should have been able to do it with something like this:
scenariodata.TimeVariableName = datetime(scenariodata.TimeVariabeName,'InputFormat','HH:mm:ss','TimeZone','Asia/Tokyo')
2 Comments
Emma
on 7 Nov 2019
Walter Roberson
on 7 Nov 2019
Add the duration column to the datetime column to get absolute times in datetime format.
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!