How to convert date/time from excel in 2 separate columns to a single date/time variable in matlab

조회 수: 2 (최근 30일)
I have a long data spreadsheet in excel which has date in 1 column and time in a separate column.
Example:
Date 08/09/2018
Time 04:12:32
I would like to convert each date/time pair into a single value representing the date and time, so that I can follow the exact times of other variables from this excel spreadsheet.
Is there a way to do this?

답변 (3개)

Star Strider
Star Strider 2018년 10월 30일
One option:
dn = [datenum({'08/09/2018'; '08/10/2018'}, 'mm/dd/yyyy') + rem(datenum({'04:12:32'; '04:12:35'}, 'HH:MM:SS'),1)];
dt = datetime(dn, 'ConvertFrom','datenum')
dt =
09-Aug-2018 04:12:32
10-Aug-2018 04:12:35

Peter Perkins
Peter Perkins 2018년 10월 31일
The right answer depends on how they are stored in the spreadsheet and what version of MATLAB you are using.
In recent versions, assuming they are stored appropriately in the spreadsheet, readtable should create a table with a datetime variable for the dates, and a duration variable for the times. Just add those two together and create a new variable in the table.
Otherwise, you may end up with text, or numbers that you will need to convert. Mostly that's easy, unless you end up with text for the times in an older version of MATLAB. For that, use text2duration on the FEX.

Michael Wolf
Michael Wolf 2018년 11월 1일
Update: I learned that the MS Excel saves dates as a number greater than 1 and times as a decimal (<1), and that a user can add the date number to the time number to obtain a combined date-time. I then used datestr() to convert this number to a date-time string (formatted as '11-Aug-2022 01:14:20')
I now have one 1x122 double composed of these date/times and another 1 x 122 double consisting of measurements at each date/time and am wondering how to combine these two series, such that each time can be paired to its corresponding data value.
  댓글 수: 1
Peter Perkins
Peter Perkins 2018년 11월 1일
You have left out a crucial step in either your description, or your code. Excel counts days from 1900. datestr uses MATL:AB's (old) convention of counting days since 0.
Unless you are using a pretty old version of MATLAB, use readtable. Then follow my previous advice to use datetimes, not datenums. If what you find yourself with is a set of Excel serial date numbers, there is a very easy conversion to datetime, see 'ConvertFrom' in the doc.

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

카테고리

Help CenterFile Exchange에서 Spreadsheets에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by