Combine date vector into single column

조회 수: 3 (최근 30일)
BenL
BenL 2017년 1월 13일
댓글: Steph 2019년 2월 18일
I have a n X 6 matrix, with time data:
1st col = yyyy (e.g. 2016)
2nd col = mm (e.g. 10 for Oct)
3rd col = day (e.g. 1)
4th col = hour
5th col = min
6th col = seconds
I need to combine them into a n X 1 (e.g. 1-Oct-2016 00:00:00). How can I do that?
My initial data comes in the form of serial date (e.g. 4.264400001156250e+04 for 1-Oct-2016 00:00:00)
I used this function to convert into a date vector, but am stuck from here:
date_vec = datevec(datestr(x2mdate(raw_data)));
Should I be doing this? My goal is to export to excel for it to be read properly (need to plot a time series). Currently when it goes to the next day, instead of showing up the date of the next day, it simple wraps back to AM of the same day.
e.g.
42644.99999
42644.99999
42645
42645
  댓글 수: 2
Stephen23
Stephen23 2017년 1월 19일
편집: Stephen23 2017년 1월 19일
Why not just use datenum to convert the dates to serial date numbers ? Then each date is a scalar, and you can put them all into one column, just like you ask for.

댓글을 달려면 로그인하십시오.

답변 (2개)

the cyclist
the cyclist 2017년 1월 13일
Would something like this work?
raw_data = [2016 10 1 3 45 50;
2017 1 1 4 15 20]
arrayfun(@datestr,datenum(raw_data),'UniformOutput',false)
  댓글 수: 5
BenL
BenL 2017년 1월 15일
Actually, my raw dates come in the Excel serial format (e.g. 4.264400001156250e+04 = 01-Oct-2016 00:00:00)
I need to convert into such a format -> 01-Oct-2016 00:00:00 and store it into the first column of a matrix A ( type double).
I tried your initial method:
dates(:,:) = arrayfun(@datestr,datenum(raw_data(:,:)),'UniformOutput',false)
But because it was cell array, when I tried storing into the matrix:
A(:,1) = dates(:,1);
It says:
The following error occurred converting from cell to double: Error using double Conversion to double from cell is not possible.
How can I transfer the data to that matrix?
Stephen23
Stephen23 2017년 1월 15일
편집: Stephen23 2017년 1월 15일
"I need to convert into such a format -> 01-Oct-2016 00:00:00 and store it into the first column of a matrix A ( type double)."
A string with multiple characters has multiple columns (one per character), so cannot be put into one column of another matrix, unless that other matrix is a cell array. You could store this string in a character array (with multiple columns) or a cell array (with one column), but certainly not in a numeric array with one column. Not unless you convert it to a serial date number first.

댓글을 달려면 로그인하십시오.


Peter Perkins
Peter Perkins 2017년 1월 19일
Unless you're using a version of MATLAB older than R2014b, you should be using datetimes:
>> datetime(4.264400001156250e+04,'ConvertFrom','Excel')
ans =
datetime
01-Oct-2016 00:00:00
  댓글 수: 3
Peter Perkins
Peter Perkins 2019년 2월 17일
The literal answer is timeofday, subtraction, and some form of convertTo, but you probably DON'T actually want to do that. Unless yu have a specific reason, stick with datetimes.
Also, it's considered bad form to tack a completely unrelated question on the end of a two-year-old thread.
Steph
Steph 2019년 2월 18일
Yes Peter you are right, but I thought it was related to the original question, as I also have each element of date time seperately (6 arrays) and was trying to get 2 different columns one for each date and time.
I will open a new thread if I can not find the answer I am looking for.
Tnx.

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Time Series Objects에 대해 자세히 알아보기

태그

Community Treasure Hunt

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

Start Hunting!

Translated by