Using datenum with a structure field

I'm working with a structure called data and there is a data.DATE field with values in format of 'yyyy-mm-dd HH:MM'.
When I try to replace the values in the structure field with
data.DATE = datenum(data.DATE, 'yyyy-mm-dd HH:MM');
I get an error of
Error using datenum
Too many input arguments.
This works fine for a cell array but not for the structure field. I guess I could split the data.DATE using regexp but was hoping to get this done in one line.
Any help / suggestions would be appreciated.

 Akzeptierte Antwort

Walter Roberson
Walter Roberson am 30 Dez. 2017

0 Stimmen

data.DATE = datenum({data.DATE}, 'yyyy-mm-dd HH:MM')

3 Kommentare

Dave
Dave am 30 Dez. 2017
I tried this, but got this error then: "Scalar structure required for this assignment."
temp = num2cell( datenum({data.DATE}, 'yyyy-mm-dd HH:MM') );
[data.DATE] = temp{:};
Dave
Dave am 30 Dez. 2017
That did it. Thanks

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (1)

Peter Perkins
Peter Perkins am 5 Jan. 2018

1 Stimme

As Walter pointed out, there were two things going on, both having to do with the fact that
s.Field
for a non-scalar struct is a complicated thing. Not enough to go on in your post to know for sure, but you might find that replacing your struct array with a table (or even a timetable, in 16b+) makes your like easier. Unless you have hierarchical data (and even then, some of the time), tables are usually more convenient for messing with data.
And as always, consider using datetime instead of datenum.

Kategorien

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by